算法与数据结构:C语言的整数数组全排列(源码)

本文介绍了一种通过特定算法实现数组元素的排列和排序的方法。该算法首先对数组进行排序,然后通过查找下一个更大的排列来生成所有可能的排列组合。代码示例中包括了关键函数的定义,如元素交换、子数组反转、寻找下一个排列等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

复制代码
 1 # include <stdio.h>
 2 # define N 3
 3 
 4 void swap(int arr[], int num1, int num2) {
 5         int t = arr[num1];
 6         arr[num1] = arr[num2];
 7         arr[num2] = t;
 8     }
 9     
10 void reverse(int arr[], int num1, int num2) {
11         int i;
12         for (i = 0; i < (num2 - num1) / 2; i++) {
13             swap(arr, num1 + i, num2 - 1 - (i));
14         }
15     }
16 
17 int nextArr(int arr[]) {
18         int left = -1;
19         int right = -1;
20         int i;
21         for (i = N - 1; i > 0; i--) {
22             if (arr[i - 1< arr[i]) {
23                 left = i - 1;
24                 break;
25             }
26         }
27         if (left < 0) {
28             return 0;
29         }
30 
31 
32         for (i = N - 1; i >= left; i--) {
33             if (arr[i] > arr[left]) {
34                 right = i;
35                 break;
36             }
37         }
38         swap(arr, left, right);
39         reverse(arr, left + 1, N);
40         return 1;
41     }
42     
43 int sort(int arr[]){
44     int i,j,temp;
45     for(i=0;i<=N;i++){
46         for(j=0;j<N-i;j++){
47             if(arr[j]>arr[j+1]){
48                 temp=arr[j];
49                 arr[j]=arr[j+1];
50                 arr[j+1]=temp;
51             }
52         }
53     }
54     return arr[N];
55 }
56 
57 void syarrange(int arr[]){
58         int i;
59         arr[N]=sort(arr);
60         do{
61             for (i = 0; i < N; i++) {
62                 printf("%d ",arr[i]);
63             }
64             printf("\n");
65         }while(nextArr(arr)==1);
66 }
67 
68 int main(){
69         int arr[N]={3,1,2};
70         syarrange(arr);
71         getchar();
72         return 0;
73 }
复制代码

本文转自施杨博客园博客,原文链接:http://www.cnblogs.com/shiyangxt/archive/2009/08/16/1547161.html,如需转载请自行联系原作者
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值