解题思路:首先我们需要先去判断这个数到底是不是完数,如果是,我们才对其找出完全的因子,然后我们用一个字符串来记录这个数的因子,然后输出
还要记住1不是合数它就没有因子,因此下面的循环从2开始
注意事项:字符串str在每一次记录完了之后记得要清零
参考代码:public static void main(String[] args) {
Scanner data=new Scanner(System.in);
int N=data.nextInt();
String str =" ";
//这个for循环是用来寻找到完数
for (int i=2;i<N;i++){
str=" ";
//这个if判断是找到完数之后,把因子给记录下来
if (judge(i)){
//记录因子
for (int j=1;j<i;j++){
if (i%j==0){
str +=j;
//这个是为了保证输出的格式
str +=" ";
}
}
System.out.println(i+" its factors are"+str);
}
}
}
//用来判断是不是合数
public static boolean judge(int i){
int sum=0;
for (int n=1;n<i;n++){
if (i%n==0){
sum +=n;
}
}
if (sum==i){
return true;
}else {
return false;
}
}
0.0分
28 人评分
回文数字 (C++代码)浏览:822 |
C语言程序设计教程(第三版)课后习题9.1 (C++代码)浏览:560 |
点我有惊喜!你懂得!浏览:1220 |
陶陶摘苹果 (C语言代码)浏览:1604 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:564 |
C语言程序设计教程(第三版)课后习题7.3 (C语言代码)浏览:619 |
计算质因子 (C++代码)浏览:1618 |
P1001 (C语言代码)浏览:800 |
A+B for Input-Output Practice (II) (C语言代码)浏览:990 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:510 |