C语言

C语言亲密数实例解析

时间:2024-10-28 23:18:18 C语言 我要投稿
  • 相关推荐

C语言亲密数实例解析

  如果整数A的全部因子(包括1,不包括A本身)之和等于B;且整数B的全部因子(包括1,不包括B本身)之和等于A,则将整数A和B称为亲密数。求3000以内的全部亲密数。以下是小编为大家搜索整理的C语言亲密数实例解析,希望能给大家带来帮助,更多精彩内容请及时关注我们应届毕业生考试网!

  *问题分析与算法设计

  按照亲密数定义,要判断数a是否有亲密数,只要计算出a的全部因子的累加和为b,再计算b的全部因子的累加和为n,若n等于a则可判定a和b是亲密数。计算数a的各因子的算法:

  用a依次对i(i=1~a/2)进行模运算,若模运算结果等于0,则i为a的一个因子;否则i就不是a的因子。

  *程序说明与注释

  #include

  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

  printf("%4d..%4d ",a,b); /*若n=a,则a和b是一对亲密数,输出*/

  }

  }

  *运行结果

  There are following friendly--numbers pair smaller than 3000:

  220.. 284 1184.. 1210 2620.. 2924

【C语言亲密数实例解析】相关文章:

C语言数组实例解析10-21

C语言的结构与联合的实例分析06-30

C语言条件编译分析实例08-18

C语言快速排序实例代码06-04

Swift与C语言指针结合使用实例09-21

C语言选择排序算法及实例代码07-25

C语言插入排序算法及实例代码07-02

C语言实现归并排序算法实例09-18

C语言教程实例:1到100求和10-05

C语言以数据块的形式读写文件实例代码10-09