栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

1149: 组合三位数之二 C语言

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

1149: 组合三位数之二 C语言

1149: 组合三位数之二
时间限制: 1 Sec 内存限制: 128 MB
提交: 3383 解决: 2286
[状态] [讨论版] [提交] [命题人:admin]
题目描述
把1,2,3,4,5,6,7,8,9,组成三个三位数(每个数只能用一次),第二个数是第一个数的2倍,第三个数是第一个数的3倍,这三个三位数各是多少?答案可能有很多组,请按第一个数的升序顺序输出每组的三个三位数。
输入

输出
输出所有满足条件的三位数组合,按第一个数的升序顺序输出。
样例输出 Copy
192 384 576

#include 


// 函数记录1-9数字使用的次数,如果都只使用一次返回1,否则返回-1 
int Str(char b[])
{
    int a[9] = {0};
    int index;
    for(index = 0; index < 9; index++ )
    {
        switch(b[index] )
        {
        case '1':
        {
            a[0] ++;
            break;
        }
        case '2':
        {
            a[1] ++;
            break;
        }
        case '3':
        {
            a[2] ++;
            break;
        }
        case '4':
        {
            a[3] ++;
            break;
        }
        case '5':
        {
            a[4] ++;
            break;
        }
        case '6':
        {
            a[5] ++;
            break;
        }
        case '7':
        {
            a[6] ++;
            break;
        }
        case '8':
        {
            a[7] ++;
            break;
        }
        case '9':
        {
            a[8] ++;
            break;
        }
        }
    }
    if (a[0] == 1 && a[1] == 1 && a[2] == 1 && a[3] == 1 && a[4] == 1 &&
            a[5] == 1 && a[6] == 1 && a[7] == 1 && a[8] == 1 )
    {
        return 1;
    }
    return -1;
}


int main()
{
    int i ;
    char b[10] = {0};
    
    for (i=100; i <333; i++)
    {
        sprintf(b, "%d%d%d", i, i*2, i*3 );
        if ( Str(b) == 1 )
        {
            printf( "%d %d %dn", i, i*2, i*3 );
 
        }
    }
 
    return 0;
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/629528.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号