用C语言输出1000以内所有的完数
我的做法:#include<stdio.h>intmain(){inti,n,sum;for(n=1;n<=1000;n++){sum=0;for(i=1;i<n;i++...
我的做法:
#include<stdio.h>
int main()
{
inti,n,sum;
for(n=1;n<=1000;n++)
{
sum=0;
for(i=1;i<n;i++)
{
if(n%i==0)
{sum=sum+i;}
if(sum==n)
{printf("%4d",n);}
}
}
return0;
}
输出结果却是:
6 6 6 24 24 24 24 28 28 28 28 28 28 28 28 28 28 28 28 28
28 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496Press any key to continue
可以帮忙看一下吗,谢谢! 展开
#include<stdio.h>
int main()
{
inti,n,sum;
for(n=1;n<=1000;n++)
{
sum=0;
for(i=1;i<n;i++)
{
if(n%i==0)
{sum=sum+i;}
if(sum==n)
{printf("%4d",n);}
}
}
return0;
}
输出结果却是:
6 6 6 24 24 24 24 28 28 28 28 28 28 28 28 28 28 28 28 28
28 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496 496
496 496 496 496 496 496 496 496 496Press any key to continue
可以帮忙看一下吗,谢谢! 展开
6个回答
展开全部
#include<stdio.h>
int main()
{
int i,n,sum;//
for(n=1;n<=1000;n++)
{
sum=0;
for(i=1;i<n;i++)
{
if(n%i==0)
{sum=sum+i;}
//if(sum==n)
//{printf("%4d",n);}
}
if(sum==n)
{printf("%4d",n);}
}
return 0;
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include <stdio.h>
//构造一个方法用来自动向数组中添加新元素;
void add(int a[],int j){
int i;
for(i=0;i<100;i++){
if(a[i]=='\0'){
a[i]=j;
break;
}
}
}
void main(){
int n=0,i=0,sum;
//静态变量;
static int m[10];
for(n = 2;n<=1000;n++){
sum=0;
for(i=1;i<n;i++){
if(n%i==0){
sum = sum+i;
add(m,i);
}
}
if(sum==n){
printf("%d是合数\n",n);
printf("包含的因子有:\n");
for(i=0;i<10;i++){
if(m[i]=='\0'){
break;
}
printf("%d\n",m[i]);
}
}else{
//初始化数组元素;
for(i=0;i<10;i++){
m[i]='\0';
}
}
}
}
//构造一个方法用来自动向数组中添加新元素;
void add(int a[],int j){
int i;
for(i=0;i<100;i++){
if(a[i]=='\0'){
a[i]=j;
break;
}
}
}
void main(){
int n=0,i=0,sum;
//静态变量;
static int m[10];
for(n = 2;n<=1000;n++){
sum=0;
for(i=1;i<n;i++){
if(n%i==0){
sum = sum+i;
add(m,i);
}
}
if(sum==n){
printf("%d是合数\n",n);
printf("包含的因子有:\n");
for(i=0;i<10;i++){
if(m[i]=='\0'){
break;
}
printf("%d\n",m[i]);
}
}else{
//初始化数组元素;
for(i=0;i<10;i++){
m[i]='\0';
}
}
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询