题目背景
本题为提交答案题,您可以写程序或手算在本机上算出答案后,直接提交答案文本,也可提交答案生成程序。
题目描述
将1,2,…,9共9个数分成三组,分别组成三个三位数,且使这三个三位数构成1:2:3的比例,试求出所有满足条件的三个三位数。
输入输出格式
输入格式:
木有输入
输出格式:
若干行,每行3个数字。按照每行第一个数字升序排列。
输入输出样例
输入样例#1:
输出样例#1:
192 384 576
…
(输出被和谐了)
# include <iostream>
using namespace std;
int main(){
int a, r[10], i, j, n;
bool m;
for(a = 123; a < 329; ++a){//因为a的最小值为123,最大值不可能到340,而330多两个3也不成立,所以a的范围可以确定出来了。
r[1] = a / 100;
r[2] = a / 10 % 10;
r[3] = a % 10;
r[4] = 2 * a / 100;
r[5] = 2 * a / 10 % 10;
r[6] = 2 * a % 10;
r[7] = 3 * a / 100;
r[8] = 3 * a / 10 % 10;
r[9] = 3 * a % 10;//求出三个数的每个数位
m = true;
for(i = 1; i <= 9; ++i){
for(j = i + 1; j <= 9; ++j){
if(r[i] > r[j]){
n = r[i];
r[i]= r[j];
r[j] = n;
}
}
}//对这9个数进行排序
for(i = 1; i <= 9; ++i){
if(r[i] != i){
m = false;
}
}//如果数的顺序不对,那么就是有重复的数字
if(m == true){
cout<<a<<" "<<2 * a<<" "<<3 * a<<endl;
}//否则,输出三个数即可
}
return 0;
}
初学者容易犯的问题,比如变量名字是a,很多人写到最后++a写成++i,习惯性犯错~~~~~~~要避免!