阅读量:1
以下是一个用C语言实现全排列的算法示例:
#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; }
在这个示例中,我们首先定义了一个swap
函数用于交换两个字符的位置。然后定义了一个permute
函数用于递归地生成全排列。最后在main
函数中定义一个字符串"ABC",并调用permute
函数来生成全排列。最终输出所有可能的全排列结果。