算法竞赛入门经典 习题2-6排列(permutation)

题目要求:用1,2,3,…,9组成3个三位数abc,def和ghi,每个数字恰好使用一次,要
求abc:def:ghi=1:2:3。按照“abc def ghi”的格式输出所有解,每行一个解。提示:不必
太动脑筋。


暴力解法:

#include<stdio.h>
int main()
{
    int a,b,c,d,e,f,g,h,i;
    for(a=1; a<=9; a++)
    {
        for(b=1; b<=9; b++)
        {
            for(c=1; c<=9; c++)
            {
                for(d=1; d<=9; d++)
                {
                    for(e=1; e<=9; e++)
                    {
                        for(f=1; f<=9; f++)
                        {
                            for(g=1; g<=9; g++)
                            {
                                for(h=1; h<=9; h++)
                                {
                                    for(i=1; i<=9; i++)
                                    {
                                        if((2*(a*100+b*10+c)==1*(d*100+e*10+f))&&(3*(a*100+b*10+c)==1*(g*100+h*10+i))&&(a!=b)&&(a!=c)&&(a!=d)&&(a!=e)&&(a!=f)&&(a!=g)&&(a!=h)&&(a!=i)&&(b!=c)&&(b!=d)&&(b!=e)&&(b!=f)&&(b!=g)&&(b!=h)&&(b!=i)&&(c!=d)&&(c!=e)&&(c!=f)&&(c!=g)&&(c!=h)&&(c!=i)&&(d!=e)&&(d!=f)&&(d!=g)&&(d!=h)&&(d!=i)&&(e!=f)&&(e!=g)&&(e!=h)&&(e!=i)&&(f!=g)&&(f!=h)&&(f!=i)&&(g!=h)&&(g!=i)&&(h!=i))
                                        {
                                            printf("%d,%d,%d\n",a*100+b*10+c,d*100+e*10+f,g*100+h*10+i);
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
    return 0;
}

优解:

#include <stdio.h>
#include <string.h>
int main()
{
    int abc, def, ghi;
    int a[10], count = 0;


    memset(a, 0, sizeof(a));


    for(abc = 123; abc <= 333; abc++)
    {
        def = 2*abc;
        ghi = 3*abc;


        a[abc/100] = a[abc/10%10] = a[abc%10] = 1;
        a[def/100] = a[def/10%10] = a[def%10] = 1;
        a[ghi/100] = a[ghi/10%10] = a[ghi%10] = 1;
        int i;
        for( i = 1; i <= 9; i++)
            count += a[i];


        if(count == 9) printf("%d,%d,%d\n", abc, def, ghi);
        count = 0;
        memset(a, 0, sizeof(a));
    }
    return 0;
}
优解思路:将可能出现的数字座位数组的下标,加和判断是否为9,是则符合条件,不是说明有重复。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值