c语言

c语言全排列递归算法怎么使用

小亿
89
2024-03-16 20:29:48
栏目: 编程语言

以下是使用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函数进行全排列的计算。程序将输出所有可能的排列组合。

0
看了该问题的人还看了