Generar todas las permutaciones posibles de un Número divisible por N

Dada una string numérica S , la tarea es imprimir todas las permutaciones de la string que son divisibles por N .

Ejemplos:

Entrada: N = 5, S = “125” 
Salida: 125 215
Explicación: 
Todas las permutaciones posibles son S son {125, 152, 215, 251, 521, 512}. 
De estas 6 permutaciones, solo 2 {125, 215} son divisibles por N (= 5).

Entrada: N = 7, S = “4321” 
Salida: 4312 4123 3241

Enfoque: La idea es generar todas las permutaciones posibles y para cada permutación, verificar si es divisible por N o no. Para cada permutación que resulte ser divisible por N, imprímalas.

A continuación se muestra la implementación del enfoque anterior:

C++14

// C++ Program to implement
// the above approach
#include <bits/stdc++.h>
using namespace std;
 
// Function to Swap two
// characters
void swap_(char& a, char& b)
{
    char temp;
    temp = a;
    a = b;
    b = temp;
}
 
// Function to generate all permutations
// and print the ones that are
// divisible by the N
void permute(char* str, int l, int r, int n)
{
    int i;
 
    if (l == r) {
 
        // Convert string to integer
        int j = atoi(str);
 
        // Check for divisibility
        // and print it
        if (j % n == 0)
            cout << str << endl;
 
        return;
    }
 
    // Print all the permutations
    for (i = l; i < r; i++) {
 
        // Swap characters
        swap_(str[l], str[i]);
 
        // Permute remaining
        // characters
        permute(str, l + 1, r, n);
 
        // Revoke the swaps
        swap_(str[l], str[i]);
    }
}
 
// Driver Code
int main()
{
    char str[100] = "125";
    int n = 5;
    int len = strlen(str);
 
    if (len > 0)
        permute(str, 0, len, n);
 
    return 0;
}

Java

// Java program to implement
// the above approach
class GFG{
 
// Function to Swap two
// characters
static void swap_(char []a, int l, int i)
{
    char temp;
    temp = a[l];
    a[l] = a[i];
    a[i] = temp;
}
 
// Function to generate all permutations
// and print the ones that are
// divisible by the N
static void permute(char[] str, int l,
                         int r, int n)
{
    int i;
 
    if (l == r)
    {
         
        // Convert String to integer
        int j = Integer.valueOf(String.valueOf(str));
 
        // Check for divisibility
        // and print it
        if (j % n == 0)
            System.out.print(String.valueOf(str) + "\n");
 
        return;
    }
 
    // Print all the permutations
    for(i = l; i < r; i++)
    {
         
        // Swap characters
        swap_(str, l, i);
 
        // Permute remaining
        // characters
        permute(str, l + 1, r, n);
 
        // Revoke the swaps
        swap_(str, l, i);
    }
}
 
// Driver Code
public static void main(String[] args)
{
    String str = "125";
    int n = 5;
    int len = str.length();
 
    if (len > 0)
        permute(str.toCharArray(), 0, len, n);
}
}
 
// This code is contributed by amal kumar choubey

Python3

# Python3 Program to implement
# the above approach
 
# Function to generate all
# permutations and print
# the ones that are
# divisible by the N
def permute(st, l, r, n):
 
    if (l == r):
 
        # Convert string
        # to integer
        p = ''.join(st)
        j = int(p)
 
        # Check for divisibility
        # and print it
        if (j % n == 0):
            print (p)
 
        return
 
    # Print all the
    # permutations
    for i in range(l, r):
 
        # Swap characters
        st[l], st[i] = st[i], st[l]
 
        # Permute remaining
        # characters
        permute(st, l + 1, r, n)
 
        # Revoke the swaps
        st[l], st[i] = st[i] ,st[l]
 
# Driver Code
if __name__ == "__main__":
 
    st = "125"
    n = 5
    length = len(st)
 
    if (length > 0):
      p = list(st)
      permute(p, 0, length, n);
 
# This code is contributed by rutvik_56

C#

// C# program to implement
// the above approach
using System;
 
class GFG{
  
// Function to Swap two
// characters
static void swap_(char []a, int l,
                            int i)
{
    char temp;
    temp = a[l];
    a[l] = a[i];
    a[i] = temp;
}
  
// Function to generate all permutations
// and print the ones that are
// divisible by the N
static void permute(char[] str, int l,
                         int r, int n)
{
    int i;
  
    if (l == r)
    {
         
        // Convert String to integer
        int j = Int32.Parse(new string(str));
  
        // Check for divisibility
        // and print it
        if (j % n == 0)
            Console.Write(new string(str) + "\n");
  
        return;
    }
  
    // Print all the permutations
    for(i = l; i < r; i++)
    {
         
        // Swap characters
        swap_(str, l, i);
  
        // Permute remaining
        // characters
        permute(str, l + 1, r, n);
  
        // Revoke the swaps
        swap_(str, l, i);
    }
}
  
// Driver Code
public static void Main(string[] args)
{
    string str = "125";
    int n = 5;
    int len = str.Length;
  
    if (len > 0)
        permute(str.ToCharArray(), 0, len, n);
}
}
 
// This code is contributed by rutvik_56

Javascript

<script>
 
// Javascript program to implement
// the above approach
 
// Function to Swap two
// characters
function swap_(a, l, i)
{
    let temp;
    temp = a[l];
    a[l] = a[i];
    a[i] = temp;
}
 
// Function to generate all permutations
// and print the ones that are
// divisible by the N
function permute(str, l, r, n)
{
    let i;
  
    if (l == r)
    {
         
        // Convert String to integer
        let j = parseInt((str).join(""));
  
        // Check for divisibility
        // and print it
        if (j % n == 0)
            document.write((str).join("") + "<br>");
  
        return;
    }
  
    // Print all the permutations
    for(i = l; i < r; i++)
    {
         
        // Swap characters
        swap_(str, l, i);
  
        // Permute remaining
        // characters
        permute(str, l + 1, r, n);
  
        // Revoke the swaps
        swap_(str, l, i);
    }
}
 
// Driver Code
let str = "125";
let n = 5;
let len = str.length;
 
if (len > 0)
    permute(str.split(""), 0, len, n);
 
// This code is contributed by avanitrachhadiya2155
 
</script>
Producción: 

125
215

 

Complejidad temporal: O(N!)
Espacio auxiliar: O(N)

Publicación traducida automáticamente

Artículo escrito por manavgoswami001 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *