以下是一個(gè)用C語(yǔ)言實(shí)現(xiàn)全排列的算法示例:
#include <stdio.h>
#include <string.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;
}
在這個(gè)示例中,我們首先定義了一個(gè)swap
函數(shù)用于交換兩個(gè)字符的位置。然后定義了一個(gè)permute
函數(shù)用于遞歸地生成全排列。最后在main
函數(shù)中定義一個(gè)字符串"ABC",并調(diào)用permute
函數(shù)來(lái)生成全排列。最終輸出所有可能的全排列結(jié)果。