以下是使用C語言實現全排列的遞歸算法示例代碼:
#include <stdio.h>
void swap(char *a, char *b) {
char temp = *a;
*a = *b;
*b = temp;
}
void permute(char *str, int start, int end) {
if(start == end) {
printf("%s\n", str);
} else {
for(int i = start; i <= end; i++) {
swap(&str[start], &str[i]);
permute(str, start+1, end);
swap(&str[start], &str[i]);
}
}
}
int main() {
char str[] = "ABC";
int n = strlen(str);
permute(str, 0, n-1);
return 0;
}
在這個示例代碼中,swap
函數用于交換數組中兩個元素的位置,permute
函數實現了全排列算法的遞歸部分。主函數中定義了一個字符串,然后調用permute
函數進行全排列的計算。程序將輸出所有可能的排列組合。