一道c语言的题 大家帮帮我啊 期末就靠他了

若正整数A的所有因子(包括1但不包括自身)之和为B,而B的因子之和为A,则称A和B为一对亲密数。例如,6的因子之和为1+2+3=6,因此6与6为一对亲密数(即6自身构成一... 若正整数A的所有因子(包括1但不包括自身)之和为B,而B的因子之和为A,则称A和B为一对亲密数。例如,6的因子之和为1+2+3=6,因此6与6为一对亲密数(即6自身构成一对亲密数);又如220的因子之和为1+2+4+5+10+11+20+22+44+55+110=284,而284的因子之和为1+2+4+71+142=220,因此,220与284为一对亲密数。编写一个函数求n以内的所有亲密数,并统计n内所有亲密数的个数。函数调用形式:
m=fun_16(n,arr)
其中,n为所求亲密数的范围,要求100<n<1000;arr为存放亲密数的数组;函数返回亲密数的个数m。主函数完成对n的输入检验、输出亲密数和个数。
展开
 我来答
百度网友7e1c2fdd8
2008-05-30 · TA获得超过375个赞
知道答主
回答量:76
采纳率:0%
帮助的人:0
展开全部
#include<stdio.h>
int main()
{
int a,i,b,n;
printf("There are following friendly--numbers pair smaller than 3000:\n");
for(a=1;a<3000;a++) /*穷举1000以内的全部整数*/
{
for(b=0,i=1;i<=a/2;i++) /*计算数a的各因子,各因子之和存放于b*/
if(!(a%i))b+=i; /*计算b的各因子,各因子之和存于n*/
for(n=0,i=1;i<=b/2;i++)
if(!(b%i))n+=i;
if(n==a&&a<b)
printf("%4d..%4d ",a,b); /*若n=a,则a和b是一对亲密数,输出*/
}
}
只要再稍微的改一下设置成函数就满足要求 了
zss2003
2008-05-30 · TA获得超过1005个赞
知道小有建树答主
回答量:684
采纳率:0%
帮助的人:630万
展开全部
#include <stdio.h>

int factor(int m)
{
int i, sum = 0;
for(i=1; i<m; i++)
if(m%i==0)
sum = sum + i;
return sum;
}

void fun_16(int n, int arr[])
{
int i, j = 0;
for(i=1;i<=n;i++)
{
if(i==factor(factor(i)))
arr[j++] = i;
printf("%d and %d\n",i,factor(i));
}

}

void main()
{
int n;
int arr[50];
printf("请输入n(100<n<1000):");
scanf("%d",&n);
fun_16(n,arr);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
一根红梅
2008-05-30 · TA获得超过156个赞
知道小有建树答主
回答量:282
采纳率:0%
帮助的人:161万
展开全部
这 个 对高手 来说 小意思
但我这个底手 帮不了你了
来学习下
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式