C语言如何打印一个数组排列组合?

本文探讨如何使用C语言编程实现数组的全排列和组合。通过递归方式解决全排列问题,程序需要具备通用性,能适应不同数量的数组元素。对于组合问题,需要采用不同的递归策略,从数组尾部开始取数并保持偏序关系以避免重复。

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

问题来自《Linux C一站式编程》,是个挺有意思的题目。

2、定义一个数组,编程打印它的全排列。比如定义:

#define N 3 
int a[N] = { 1, 2, 3 };

则运行结果是:

$ ./a.out
1 2 3 
1 3 2 
2 1 3 
2 3 1 
3 2 1 
3 1 2

程序的主要思路是:

  1. 把第1个数换到最前面来(本来就在最前面),准备打印1xx,再对后两个数2和3做全排列。
  2. 把第2个数换到最前面来,准备打印2xx,再对后两个数1和3做全排列。
  3. 把第3个数换到最前面来,准备打印3xx,再对后两个数1和2做全排列。

可见这是一个递归的过程,把对整个序列做全排列的问题归结为对它的子序列做全排列的问题,注意我没有描述Base Case怎么处理,你需要自己想。
你的程序要具有通用性,如果改变了N和数组a的定义(比如改成4个数的数组),其它代码不需要修改就可以做4个数的全排列(共24种排列)。

完成了上述要求之后再考虑第二个问题:如果再定义一个常量M表示从N个数中取几个数做排列(N==M时表示全排列),原来的程序应该怎么改?

最后再考虑第三个问题:如果要求从N个数中取M个数做组合而不是做排列,就不能用原来的递归过程了,想想组合的递归过程应该怎么描述,编程实现它。

不考虑数组元素相同的情况,我们可以按照题目提供的思路写出如下代码:

#include <stdio.h>
#define N 3

int a[N];

void perm(int); /*求数组的全排列 */
void print();
void swap(int, int);

int main(){
    int i;
    for(i = 0; i < N; ++i){
        a
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值