频道栏目
首页 > 资讯 > 中级 > 正文

2009年5月程序员笔试考前冲刺练习系列(1)

09-05-17        来源:[db:作者]  
收藏   我要投稿

  阅读以下程序说明和C程序,将应填入__(n)__ 处的字句,写在答卷的对应栏内。

  [程序说明]

  本程序中的函数factor( m,fac,cp )用来计算正整 m ( m > 2 )的除自身以外的所有不同因子的和。该函数返回因子和,并把各因子从小到大依次存放在数组 fac 中,其因子个数存入在 cp 所指的变量中。

  例如 m=16,求得的因子为

  (1,2,4,8)

  提示:因子和为15,因子个数为4。

  程序假定正整数 m 的不同因子个数不会超过100个。

  [程序]

  # include

  # define N 100

  long factor (int m,int fac[],int *cp)

  {

  int c1, c2 , i, k;

  long s;

  fac[0] = 1;

  for(c1 = s = 1,c2 = N-1,____(1)____;;)

  {

  k = m/i;

  if (____(2)____)

  if (____(3)____)

  { fac[c1++] = i;

  fac[c2--] = k;

  s + = i+k;

  }

  else {

  fac[c1++] = i;

  s + = i;

  }

  i++;

  if(i>=k) brdak;

  }

  for (c2++;c2 <= N-1;c2++)

  ____(4)____;

  *cp=c1;

  return ____(5)____;

  答案:

  1)3分 i = 2,或 cl + 1

  2)3分 m % i == 0 (或 !(m % i) 或 m == i * k )

  3)3分 i ! = k (或 i < k )

  4)3分 fac [ cl ++ ] = fac [ c2 ]

  答 cl ++ 给 1 分,‘ = ’左右只对一半给 1 分。

  5)3分 s

相关TAG标签
上一篇:网康助天津地震局建设上网行为管理系统
下一篇:2009年5月软考程序员考前冲刺复习资料(七)
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站