c语言全排列算法怎么实现

avatar
作者
筋斗云
阅读量: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函数来生成全排列。最终输出所有可能的全排列结果。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!