Juggling Algorithm

前端 未结 2 1841
伪装坚强ぢ
伪装坚强ぢ 2021-01-27 19:06

METHOD (A Juggling Algorithm) Divide the array in different sets where number of sets is equal to GCD of n and d and move the elements within sets. If GCD is 1 as is for the abo

2条回答
  •  余生分开走
    2021-01-27 19:47

    Juggling Algorithm

    In this method, divide the array into M sets, where M = GCD (n, k), and then rotate the elements in each set.

    From the number of elements ( n ) of the array and number of rotations ( k ) to be made to the array, the GCD(n, k) number of blocks are made. Then in each block, shifting will take place to the corresponding elements in the block.

    After all the elements in all the blocks are shifted, the array will be rotated for the given number of times.

    For Example: If we want to rotate the below array by 2 positions. 1 2 3 4 5 6

      M = GCD(6, 2) = 2;
      Initial Array : 1  2  3  4  5  6   
      First Set Moves : 5   2   1   4   3   6
      Second Set Moves : 5   6   1   2   3   4          //  The array is rotated twice.
    
    public class Main
    {
    
    /*Fuction to get gcd of a and b*/
    public static int gcd(int a, int b) 
    { 
        if (b == 0) 
            return a; 
        else
            return gcd(b, a % b); 
    }
    
    /*Function to left rotate array of by d number of rotations*/
    public static void leftRotate(int arr[], int d, int n) 
    { 
        int i, j, k, temp; 
        for (i = 0; i < gcd(d, n); i++) // gcd(d,n) times the loop will iterate
        { 
            /* move i-th values of blocks */
            temp = arr[i]; 
            j = i; 
            while (true) { 
                k = j + d; 
                if (k >= n) // The element has to be shifted to its rotated position
                    k = k - n; 
                if (k == i) // The element is already in its rotated position
                    break; 
                arr[j] = arr[k]; 
                j = k; 
            } 
            arr[j] = temp; 
        }} 
    
    //  Main function
    public static void main(String[] args) 
    { 
        int arr[] = { 1, 2, 3, 4, 5, 6, 7 }; 
        int no_of_rotations = 2;
        int n = arr.length;
        System.out.println("Array Elements before rotating : "); 
        for(int i = 0 ; i < n ; i++)
        {
            System.out.print(arr[i]+ " "); // Printing elements before rotation
        }
        leftRotate(arr, no_of_rotations, n); 
        System.out.println("\nArray Elements after rotating : "); 
        for(int i = 0 ; i < n ; i++)
        {
            System.out.print(arr[i] + " "); // Printing elements after rotation
    } } }
    

提交回复
热议问题