C语言例子解析(1)

经典案例(1)

问题:无重复数字

有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?

解决思路(1)

此题可以反向思考,先完成所有可能排列组合后,排除掉不满足条件的组合,余下的就是正确结果:

  1. 准备数据 ,建立一个数组,赋予1,2,3,4组合元素
  2. 排列组合,最终组合为三位数据,建立三级嵌套循环
  3. 排除结果,限定条件为互不相同且无重复
  4. 输出最终结果,使用输出函数printf(),进行显示结果整定

源代码

#include<stdio.h>
 
int main()
{
    int i,j,k,a;
    int arr[]={1,2,3,4};// 预置元素数值
    a=sizeof(arr)/sizeof(int);// 计算元素个数
    printf("屏幕输出结果:\n");
    for(i=0;i<a;i++) { // 以下为三重循环
        for(j=0;j<a;j++) {
            for (k=0;k<a;k++) { // 确保i、j、k三位互不相同
                if (i!=k&&i!=j&&j!=k) { 
                    printf("%d%d%d\n",arr[i],arr[j],arr[k]);
                }
            }
        }
    }
    return 0;
}

代码优化

上述代码,时间复杂度为N的三次方,优化思路:排除无效循环

源代码

#include<stdio.h>
 
int main()
{
    int i,j,k,a;
    int arr[]={1,2,3,4};// 预置元素数值
    a=sizeof(arr)/sizeof(int);// 计算元素个数
    printf("屏幕输出结果:\n");
    for(i=0;i<a;i++) { // 以下为三重循环
        for(j=0;j<a;j++) {
            if (i!=j){          //先行判断,减少无效循环
                for (k=0;k<a;k++) { // 确保i、j、k三位互不相同
                    if (i!=k&&j!=k) { 
                        printf("%d%d%d\n",arr[i],arr[j],arr[k]);
                    }
                }
            }
        }
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值