1到9组成3个三位数,每个数字恰好使用一次,要求3个数的比满足1:2:3,然后输出。这个怎么入手?
经过分析发现,这三个数的中最小的那个数的百位只能在(1, 2, 3)中取,然后求出第一个数a1,将a12、a13算出,是否有重复数字,有重复,直接下一组数。
如下为代码:
for(int i = 1; i <= 3; ++ i)
{
for(int j = 1; j <= 9; ++ j)
{
if(i == j) continue;
for(int k = 1; k <= 9; ++ k)
{
if(k == i || k == j) continue;
a1 = 100*i + 10*j +k;
a2 = 2*a1;
a3 = 3*a1;
}
}
}
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。