排列(permutation) 用1,2,3,…,9组成3个三位数abc,def和ghi,每个数字恰好使用一次,要 求abc:def:ghi=1:2:3。按照“abc def ghi”的格式输出所有解

其中运用数组a[10]作为一种0/1比较器,当出现1~9是a[1~9]全变成1,一次成功实现了是否全部使用数字。

#include<stdio.h>
int main()
{
	
	for (int i = 100; i <= 333; i++) {
		int a[10] = { 0 };
		int j = 2 * i;
		int k = 3 * i;
		int sum = 0;
		a[i % 10] = 1;
		a[i / 10 % 10] = 1;
		a[i / 100 % 10] = 1;
		a[j % 10] = 1;
		a[j / 10 % 10] = 1;
		a[j / 100 % 10] = 1;
		a[k % 10] = 1;
		a[k / 10 % 10] = 1;
		a[k / 100 % 10] = 1;
		for (int n = 1; n < 10; n++) {
			sum += a[n];
		}
		if (sum == 9)printf("%d %d %d\n", i, j, k);
	}



	return 0;
}

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值