Open In App

Generate all rotations of a given string

Last Updated : 17 Jul, 2024
Summarize
Comments
Improve
Suggest changes
Like Article
Like
Save
Share
Report
News Follow

Given a string S. The task is to print all the possible rotated strings of the given string.

Examples: 

Input : S = "geeks"
Output : geeks
eeksg
eksge
ksgee
sgeek

Input : S = "abc"
Output : abc
bca
cab

Method 1 (Simple): The idea is to run a loop from i = 0 to n – 1 ( n = length of string) i.e for each point of rotation, copy the second part of the string in the temporary string and then copy the first part of the original string to the temporary string.

Below is implementation of the above approach:  

C++
// A simple C++ program to generate all rotations
// of a given string
#include<bits/stdc++.h>
using namespace std;

// Print all the rotated string.
void printRotatedString(char str[])
{
    int len = strlen(str);

    // Generate all rotations one by one and print
    char temp[len];
    for (int i = 0; i < len; i++)
    {
        int j = i;  // Current index in str
        int k = 0;  // Current index in temp

        // Copying the second part from the point
        // of rotation.
        while (str[j] != '\0')
        {
            temp[k] = str[j];
            k++;
            j++;
        }

        // Copying the first part from the point
        // of rotation.
        j = 0;
        while (j < i)
        {
            temp[k] = str[j];
            j++;
            k++;
        }

        printf("%s\n", temp);
    }
}

// Driven Program
int main()
{
    char str[] = "geeks";
    printRotatedString(str);
    return 0;
}
Java
// A simple Java program to generate all rotations
// of a given string    

class Test
{
    // Print all the rotated string.
    static void printRotatedString(String str)
    {
        int len = str.length();
     
        // Generate all rotations one by one and print
        StringBuffer sb; 
        
        for (int i = 0; i < len; i++)
        {
            sb = new StringBuffer();
            
            int j = i;  // Current index in str
            int k = 0;  // Current index in temp
     
            // Copying the second part from the point
            // of rotation.
            for (int k2 = j; k2 < str.length(); k2++) {
                sb.insert(k, str.charAt(j));
                k++;
                j++;
            }
     
            // Copying the first part from the point
            // of rotation.
            j = 0;
            while (j < i)
            {
                sb.insert(k, str.charAt(j));
                j++;
                k++;
            }
     
            System.out.println(sb);
        }
    }
    
    // Driver method
    public static void main(String[] args) 
    {
        String  str = new String("geeks");
        printRotatedString(str);
    }
}
Python
# A simple Python3 program to generate 
# all rotations of a given string 

# Print all the rotated strings. 
def printRotatedString(str): 

    lenn = len(str) 

    # Generate all rotations
    # one by one and print
    temp = [0] * (lenn)
    for i in range(lenn):     
        j = i # Current index in str 
        k = 0 # Current index in temp 

        # Copying the second part from 
        # the point of rotation. 
        while (j < len(str)): 
        
            temp[k] = str[j] 
            k += 1
            j += 1
        

        # Copying the first part from 
        # the point of rotation. 
        j = 0
        while (j < i) :
        
            temp[k] = str[j] 
            j += 1
            k += 1
        

        print(*temp, sep = "") 
    
# Driver Code
if __name__ == '__main__':
    str = "geeks"
    printRotatedString(str)
    
# This code is contributed 
# by SHUBHAMSINGH10
C#
// A simple C# program to generate 
// all rotations of a given string     
using System;
using System.Text;

class GFG
{
// Print all the rotated string. 
public static void printRotatedString(string str)
{
    int len = str.Length;

    // Generate all rotations one
    // by one and print 
    StringBuilder sb;

    for (int i = 0; i < len; i++)
    {
        sb = new StringBuilder();

        int j = i; // Current index in str
        int k = 0; // Current index in temp

        // Copying the second part from 
        // the point of rotation. 
        for (int k2 = j; k2 < str.Length; k2++)
        {
            sb.Insert(k, str[j]);
            k++;
            j++;
        }

        // Copying the first part from 
        // the point of rotation. 
        j = 0;
        while (j < i)
        {
            sb.Insert(k, str[j]);
            j++;
            k++;
        }

        Console.WriteLine(sb);
    }
}

// Driver Code 
public static void Main(string[] args)
{
    string str = "geeks";
    printRotatedString(str);
}
}

// This code is contributed 
// by Shrikant13
JavaScript
<script>

// A simple javascript program to generate
// all rotations of a given string    

// Print all the rotated string.
function printRotatedString(str)
{
    var len = str.length;
 
    // Generate all rotations one
    // by one and print
    var sb; 
    
    for(i = 0; i < len; i++)
    {
        sb = [];
        
        // Current index in str
        var j = i; 
        
        // Current index in temp
        var k = 0;  
 
        // Copying the second part from the point
        // of rotation.
        for(k2 = j; k2 < str.length; k2++)
        {
            sb.push(str.charAt(j));
            k++;
            j++;
        }
 
        // Copying the first part from the point
        // of rotation.
        j = 0;
        
        while (j < i)
        {
            sb.push(str.charAt(j));
            j++;
            k++;
        }
        document.write(sb.join("") + "<br>");
    }
}

// Driver code
var  str = "geeks";
printRotatedString(str);

// This code is contributed by Amit Katiyar 

</script>
PHP
<?php
// A simple PHP program to generate 
// all rotations of a given string

// Print all the rotated string.
function printRotatedString($str)
{
    $len = strlen($str);

    // Generate all rotations one 
    // by one and print
    $temp = " ";
    for ($i = 0; $i < $len; $i++)
    {
        $j = $i; // Current index in str
        $k = 0;  // Current index in temp

        // Copying the second part from 
        // the point of rotation.
        while ($j < $len)
        {
            $temp[$k] = $str[$j];
            $k++;
            $j++;
        }

        // Copying the first part from 
        // the point of rotation.
        $j = 0;
        while ($j < $i)
        {
            $temp[$k] = $str[$j];
            $j++;
            $k++;
        }

        echo $temp . "\n";
    }
}

// Driver Code
$str = "geeks";
printRotatedString($str);

// This code is contributed 
// by Akanksha Rai
?>

Output
geeks
eeksg
eksge
ksgee
sgeek

Time complexity: O(n2) where n is length of string
Auxiliary Space: O(n)
  
Method 2 (Tricky and Efficient): The idea is based on the efficient method to check if strings are rotations of each other or not. We concatenate str with itself, i.e., we do str.str where . is concatenation operator. Now we traverse the concatenated string from 0 to n – 1 and print all substrings of size n.

Below is the implementation of above approach:  

C++
// An efficient C++ program to print all
// rotations of a string. Space complexity O(1).
#include<bits/stdc++.h>
using namespace std;

// Print all the rotated string.
void printRotatedString(char str[])
{
    int n = strlen(str);

    int i,j,k;
    for (i=0; i<n; i++)
    {
        k=i;
      
        for (j=0; j<n; j++)
        {
            cout << str[ (k++) % n ];
        }
        cout << endl;
    }
}

// Driven Program
int main()
{
    char str[] = "geeks";
    printRotatedString(str);
    return 0;
}
Java
// A simple Java program to generate all rotations
// of a given string    

class Test
{
    // Print all the rotated string.
    static void printRotatedString(String str)
    {
        int n = str.length();
      
        StringBuffer sb = new StringBuffer(str);
        // Concatenate str with itself
        sb.append(str);
     
        // Print all substrings of size n.
        // Note that size of sb is 2n
        for (int i = 0; i < n; i++)
        {
            for (int j=0; j != n; j++)
                System.out.print(sb.charAt(i + j));
            System.out.println();
        }
    }
    
    // Driver method
    public static void main(String[] args) 
    {
        String  str = new String("geeks");
        printRotatedString(str);
    }
}
Python
# An efficient Python3 program to print  
# all rotations of a string. 

# Print all the rotated string. 
def printRotatedString(string) :
    
    n = len(string)

    # Concatenate str with itself 
    temp = string + string

    # Print all substrings of size n. 
    # Note that size of temp is 2n 
    for i in range(n) :
        
        for j in range(n) :
            print(temp[i + j], end = "")
            
        print() 

# Driver Code
if __name__ == "__main__" : 

    string = "geeks"
    printRotatedString(string)

# This code is contributed by Ryuga
C#
// A simple C# program to generate all rotations
// of a given string 
using System;
using System.Text;

class Test
{
    
    // Print all the rotated string.
    static void printRotatedString(String str)
    {
        int n = str.Length;
    
        StringBuilder sb = new StringBuilder(str);
        // Concatenate str with itself
        sb.Append(str);
    
        // Print all substrings of size n.
        // Note that size of sb is 2n
        for (int i = 0; i < n; i++)
        {
            for (int j=0; j != n; j++)
                Console.Write(sb[i + j]);
            Console.WriteLine();
        }
    }
    
    // Driver method
    public static void Main(String[] args) 
    {
        String str = "geeks";
        printRotatedString(str);
    }
}
JavaScript
<script>
// A simple javascript program to generate all rotations
// of a given string    

    // Print all the rotated string.
    function printRotatedString(str)
    {
        var n = str.length;      
        var sb = str;
        
        // Concatenate str with itself
        sb += (str);
     
        // Print all substrings of size n.
        // Note that size of sb is 2n
        for (var i = 0; i < n; i++)
        {
            for (var j = 0; j != n; j++)
                document.write(sb.charAt(i + j));
            document.write('<br>');
        }
    }
    
    // Driver method
    var  str = "geeks";
    printRotatedString(str);
    
// This code is contributed by 29AjayKumar 
</script>
PHP
<?php
// An efficient PHP program to print all
// rotations of a string.

// Print all the rotated string.
function printRotatedString($str)
{
    $n = strlen($str);

    // Concatenate str with itself
    $temp=$str.$str;

    // Print all substrings of size n.
    // Note that size of temp is 2n
    for ($i = 0; $i < $n; $i++)
    {
        for ($j = 0; $j != $n; $j++)
            print($temp[$i + $j]);
        print("\n");
    }
}

    // Driver code
    $str = "geeks";
    printRotatedString($str);
    
// This code is contributed by mits
?>

Output
geeks
eeksg
eksge
ksgee
sgeek

Time complexity: O(n2) where n is length of string
Auxiliary Space : O(n)

 



Next Article
Article Tags :
Practice Tags :

Similar Reads

Generate all rotations of a number
Given an integer n, the task is to generate all the left shift numbers possible. A left shift number is a number that is generated when all the digits of the number are shifted one position to the left and the digit at the first position is shifted to the last.Examples: Input: n = 123 Output: 231 312Input: n = 1445 Output: 4451 4514 5144 Approach:
5 min read
Javascript Program to Generate all rotations of a number
Given an integer n, the task is to generate all the left shift numbers possible. A left shift number is a number that is generated when all the digits of the number are shifted one position to the left and the digit at the first position is shifted to the last.Examples: Input: n = 123 Output: 231 312Input: n = 1445 Output: 4451 4514 5144 Approach:
3 min read
Count of rotations required to generate a sorted array
Given an array arr[], the task is to find the number of rotations required to convert the given array to sorted form.Examples: Input: arr[] = {4, 5, 1, 2, 3} Output: 2 Explanation: Sorted array {1, 2, 3, 4, 5} after 2 anti-clockwise rotations. Input: arr[] = {2, 1, 2, 2, 2} Output: 1 Explanation: Sorted array {1, 2, 2, 2, 2} after 1 anti-clockwise
11 min read
Javascript Program to Count of rotations required to generate a sorted array
Given an array arr[], the task is to find the number of rotations required to convert the given array to sorted form.Examples: Input: arr[] = {4, 5, 1, 2, 3} Output: 2 Explanation: Sorted array {1, 2, 3, 4, 5} after 2 anti-clockwise rotations. Input: arr[] = {2, 1, 2, 2, 2} Output: 1 Explanation: Sorted array {1, 2, 2, 2, 2} after 1 anti-clockwise
4 min read
Javascript Program for Check whether all the rotations of a given number is greater than or equal to the given number or not
Given an integer x, the task is to find if every k-cycle shift on the element produces a number greater than or equal to the same element. A k-cyclic shift of an integer x is a function that removes the last k digits of x and inserts them in its beginning. For example, the k-cyclic shifts of 123 are 312 for k=1 and 231 for k=2. Print Yes if the giv
3 min read
Check whether all the rotations of a given number is greater than or equal to the given number or not
Given an integer x, the task is to find if every k-cycle shift on the element produces a number greater than or equal to the same element. A k-cyclic shift of an integer x is a function that removes the last k digits of x and inserts them in its beginning. For example, the k-cyclic shifts of 123 are 312 for k=1 and 231 for k=2. Print Yes if the giv
12 min read
Generate a string whose all K-size substrings can be concatenated to form the given string
Given a string str of size N and an integer K, the task is to generate a string whose substrings of size K can be concatenated to form the given string. Examples: Input: str = "abbaaa" K = 2 Output: abaa Explanation: All substring of size 2 of parent string "abaa" are "ab", "ba" and "aa". After concatenating all these substrings, the given string "
5 min read
Generate string by incrementing character of given string by number present at corresponding index of second string
Given two strings S[] and N[] of the same size, the task is to update string S[] by adding the digit of string N[] of respective indices. Examples: Input: S = "sun", N = "966"Output: bat Input: S = "apple", N = "12580"Output: brute Approach: The idea is to traverse the string S[] from left to right. Get the ASCII value of string N[] and add it to t
4 min read
Print all possible rotations of a given Array
Given an integer array arr[] of size N, the task is to print all possible rotations of the array.Examples: Input: arr[] = {1, 2, 3, 4} Output: {1, 2, 3, 4}, {4, 1, 2, 3}, {3, 4, 1, 2}, {2, 3, 4, 1} Explanation: Initial arr[] = {1, 2, 3, 4} After first rotation arr[] = {4, 1, 2, 3} After second rotation arr[] = {3, 4, 1, 2} After third rotation arr[
8 min read
Javascript Program to Print all possible rotations of a given Array
Given an integer array arr[] of size N, the task is to print all possible rotations of the array.Examples: Input: arr[] = {1, 2, 3, 4} Output: {1, 2, 3, 4}, {4, 1, 2, 3}, {3, 4, 1, 2}, {2, 3, 4, 1} Explanation: Initial arr[] = {1, 2, 3, 4} After first rotation arr[] = {4, 1, 2, 3} After second rotation arr[] = {3, 4, 1, 2} After third rotation arr[
3 min read
Javascript Program for Maximum sum of i*arr[i] among all rotations of a given array
Given an array arr[] of n integers, find the maximum that maximizes the sum of the value of i*arr[i] where i varies from 0 to n-1. Examples: Input: arr[] = {8, 3, 1, 2} Output: 29 Explanation: Lets look at all the rotations, {8, 3, 1, 2} = 8*0 + 3*1 + 1*2 + 2*3 = 11 {3, 1, 2, 8} = 3*0 + 1*1 + 2*2 + 8*3 = 29 {1, 2, 8, 3} = 1*0 + 2*1 + 8*2 + 3*3 = 27
7 min read
Maximum sum of i*arr[i] among all rotations of a given array
Given an array arr[] of n integers, find the maximum that maximizes the sum of the value of i*arr[i] where i varies from 0 to n-1. Examples: Input: arr[] = {8, 3, 1, 2} Output: 29 Explanation: Lets look at all the rotations, {8, 3, 1, 2} = 8*0 + 3*1 + 1*2 + 2*3 = 11 {3, 1, 2, 8} = 3*0 + 1*1 + 2*2 + 8*3 = 29 {1, 2, 8, 3} = 1*0 + 2*1 + 8*2 + 3*3 = 27
15+ min read
Generate all permutations of a string that follow given constraints
Given a string, generate all permutations of it that do not contain 'B' after 'A', i.e., the string should not contain "AB" as a substring. Examples: Input : str = "ABC" Output : ACB, BAC, BCA, CBA Out of 6 permutations of "ABC", 4 follow the given constraint and 2 ("ABC" and "CAB") do not follow. Input : str = "BCD" Output : BCD, BDC, CDB, CBD, DC
11 min read
Generate a string which differs by only a single character from all given strings
Given an array of strings str[] of length N, consisting of strings of the same length, the task is to find the string which only differs by a single character from all the given strings. If no such string can be generated, print -1. In case of multiple possible answers, print any of them. Example: Input: str[] = { "abac", "zdac", "bdac"} Output: ad
15 min read
Program to generate all possible valid IP addresses from given string
Given a string containing only digits, restore it by returning all possible valid IP address combinations.A valid IP address must be in the form of A.B.C.D, where A, B, C, and D are numbers from 0-255. The numbers cannot be 0 prefixed unless they are 0. Examples : Input: 25525511135 Output: [“255.255.11.135”, “255.255.111.35”] Explanation: These ar
15+ min read
Generate string after adding spaces at specific positions in a given String
Given a string s and an array spaces[] describing the original string's indices where spaces will be added. The task is to add spaces in given positions in spaces[] and print the string formed. Examples: Input: s = "GeeksForGeeK", spaces = {1, 5, 10}Output: "G eeks ForGe eK" Explanation: The underlined characters in "GeeksForGeeK" relate to the ind
8 min read
Minimum flips to make Matrix identical for all rotations
Given a binary matrix Mat[][] of size N*N, the task is to find the minimum number of flips to be performed such that the matrix is identical for all rotations. Examples: Input: Mat[][] = {{1, 0, 0}, {0, 1, 0}, {1, 0, 1}}Output: 1Explanation: Change the element at row = 1, col = 3 from 0 to 1.Now for all the rotations the matrix is identical. Input:
9 min read
Check if all rows of a matrix are circular rotations of each other
Given a matrix of n*n size, the task is to find whether all rows are circular rotations of each other or not. Examples: Input: mat[][] = 1, 2, 3 3, 1, 2 2, 3, 1 Output: Yes All rows are rotated permutation of each other. Input: mat[3][3] = 1, 2, 3 3, 2, 1 1, 3, 2 Output: No Explanation : As 3, 2, 1 is not a rotated or circular permutation of 1, 2,
8 min read
Javascript Program to Check if all rows of a matrix are circular rotations of each other
Given a matrix of n*n size, the task is to find whether all rows are circular rotations of each other or not. Examples: Input: mat[][] = 1, 2, 3 3, 1, 2 2, 3, 1Output: YesAll rows are rotated permutationof each other.Input: mat[3][3] = 1, 2, 3 3, 2, 1 1, 3, 2Output: NoExplanation : As 3, 2, 1 is not a rotated or circular permutation of 1, 2, 3The i
2 min read
Generate a String from given Strings P and Q based on the given conditions
Given two strings P and Q, the task is to generate a string S satisfying the following conditions: Find S such that P is rearranged and Q is a substring in it.All the characters before Q in S should be smaller than or equal to the first character in Q and in lexicographic order.The rest of the characters should be present after Q in lexicographic o
7 min read
Rotations of a Binary String with Odd Value
Given a binary string. We are allowed to do circular rotation of the string without changing the relative order of the bits in the string. For Example, all possible circular rotation of string "011001" are: 101100 010110 001011 100101 110010 We are required to tell total number of distinct odd decimal equivalent possible of binary string, by doing
3 min read
Maximum contiguous 1 possible in a binary string after k rotations
Given a binary string, you can rotate any substring of this string. For Example, let string be denoted by s. Let the first element of string be represented by s[0], second element be represented by s[1] and so on. s = "100110111" Suppose, we rotate the substring starting from s[2] and ending at s[4]. Then the string after this operation will be: Re
6 min read
Minimum rotations required to get the same String | Set-2
Given a string, we need to find the minimum number of rotations required to get the same string. In this case, we will only consider Left rotations. Examples: Input : s = "geeks" Output : 5 Input : s = "aaaa" Output :1 Naive approach: The basic approach is to keep rotating the string from the first position and count the number of rotations until w
10 min read
Minimum rotations required to get the same string
Given a string, we need to find the minimum number of rotations required to get the same string. Examples: Input : s = "geeks" Output : 5 Input : s = "aaaa" Output : 1 The idea is based on below post.A Program to check if strings are rotations of each other or not Step 1 : Initialize result = 0 (Here result is count of rotations) Step 2 : Take a te
11 min read
Count rotations required to sort given array in non-increasing order
Given an array arr[] consisting of N integers, the task is to sort the array in non-increasing order by minimum number of anti-clockwise rotations. If it is not possible to sort the array, then print "-1". Otherwise, print the count of rotations. Examples: Input: arr[] = {2, 1, 5, 4, 3}Output: 2Explanation: Two anti-clockwise rotations are required
7 min read
Javascript Program to Count rotations required to sort given array in non-increasing order
Given an array arr[] consisting of N integers, the task is to sort the array in non-increasing order by minimum number of anti-clockwise rotations. If it is not possible to sort the array, then print "-1". Otherwise, print the count of rotations. Examples: Input: arr[] = {2, 1, 5, 4, 3}Output: 2Explanation: Two anti-clockwise rotations are required
3 min read
Javascript Program to Maximize count of corresponding same elements in given permutations using cyclic rotations
Given two permutations P1 and P2 of numbers from 1 to N, the task is to find the maximum count of corresponding same elements in the given permutations by performing a cyclic left or right shift on P1. Examples:  Input: P1 = [5 4 3 2 1], P2 = [1 2 3 4 5] Output: 1 Explanation: We have a matching pair at index 2 for element 3.Input: P1 = [1 3 5 2 4
4 min read
Minimum number of rotations required to convert given Matrix to another
Given two 2D arrays arr[][] and brr[][] of equal size. The task is to find the minimum number of rotations required either clockwise or anticlockwise to convert arr[][] to brr[][], in the following manner: +x means x rotation in clockwise direction-x means x rotation in anti-clockwise direction0 means no rotation needed, andNA means rotation is not
8 min read
Count of possible rotations of given Array to remove largest element from first half
Given an array arr[ ] with even length N, the task is to find the number of cyclic shifts (rotations) possible for this array, such that the first half of array does not contain the maximum element. Examples: Input: N = 6, arr[ ] = { 3, 3, 5, 3, 3, 3 }Output: 3Explanation: The maximum element here is 5 at index 2. This 5 can be shifted to second ha
6 min read
Find maximum value of Sum( i*arr[i]) with only rotations on given array allowed
Given an array arr[] of size N, the task is to find the maximum possible sum of i*arr[i] when the array can be rotated any number of times. Examples : Input: arr[] = {1, 20, 2, 10}Output: 72.We can get 72 by rotating array twice.{2, 10, 1, 20}20*3 + 1*2 + 10*1 + 2*0 = 72 Input: arr[] = {10, 1, 2, 3, 4, 5, 6, 7, 8, 9}Output: 330We can get 330 by rot
12 min read
  翻译: