Write a C program to print all permutations of a given string

A permutation, also called an “arrangement number” or “order,” is a rearrangement of the elements of an ordered list S into a one-to-one correspondence with S itself. A string of length n has n! permutation.
Source: Mathword(http://mathworld.wolfram.com/Permutation.html)

Below are the permutations of string ABC.



ABC, ACB, BAC, BCA, CAB, CBA

Here is a solution using backtracking.

# include <stdio.h> 
/* Function to swap values at two pointers */ 
void swap (char *x, char *y) 
{     
    char temp;     
    temp = *x;     
    *x = *y;     
    *y = temp; 
}   
/* Function to print permutations of string    
This function takes three parameters:   
 1. String    2. Starting index of the string    
 3. Ending index of the string. */ 
 void permute(char *a, int i, int n)  
 {    
     int j;     
     if (i == n)      
     printf("%s\n", a);    
     else   
     {         
        for (j = i; j <= n; j++)        
        {           
            swap((a+i), (a+j));           
            permute(a, i+1, n);           
            swap((a+i), (a+j)); 
            //backtrack        
        }    
    } 
}   

/* Driver program to test above functions */ 
int main() 
{    
    char a[] = "ABC"; 
    permute(a, 0, 2);    
    getchar();    
    return 0; 
}

 


 

Output:

ABC
ACB
BAC
BCA
CBA
CAB

 

Algorithm Paradigm: Backtracking
Time Complexity: O(n*n!)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值