当前所在位置:珠峰网资料 >> 计算机 >> 计算机等级考试 >> 正文
2015年计算机二级C语言上机题库及答案(48)
发布时间:2011/9/16 11:22:21 来源:城市学习网 编辑:ziteng
  一、填空题:用筛选法可得到2~n(n<10000)之间的所有素数,方法是:首先从素数2开始,将所有2的倍数的数从数表中删去(把数表中相应位置的值置成0);接着从数表中找下一个非0数,并从数表中删去该数的所有倍数;依此类推,直到所找的下一个数等于n为止。这样会得到一个序列:

  2,3,5,7,11,13,17,19,23,……

  函数fun用筛选法找出所有小于等于n的素数,并统计素数的个数作为函数值返回。

  请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。

  注意:源程序存放在考生文件夹下BLANK1.C中。

  不得增行或删行,也不得更改程序的结构!

  给定源程序:

  #include

  int fun(int n)

  {int a[10000], i,j, count=0;

  for (i=2; i<=n; i++) a[i] = i;

  i = 2;

  while (i

  /**********found**********/

  for (j=a[i]*2; j<=n; j+=___1___)

  a[j] = 0;

  i++;

  /**********found**********/

  while (___2___==0)

  i++;

  }

  printf("\nThe prime number between 2 to %d\n", n);

  for (i=2; i<=n; i++)

  /**********found**********/

  if (a[i]!=___3___)

  {count++; printf(count?"]": "\n]",a[i]);}

  return count;

  }

  main()

  {int n=20, r;

  r = fun(n);

  printf("\nThe number of prime is : %d\n", r);

  }

  解题答案:

  /**********第一空**********/

  for (j=a[i]*2; j<=n; j+=a[i])

  /**********第二空**********/

  while (a[i]==0)

  /**********第三空**********/

  if (a[i]!=0)

  ****************************************** [NextPage]    二、改错题:

  给定程序MODI1.C中函数fun的功能是: 为一个偶数寻找两个素数, 这两个素

  数之和等于该偶数,并将这两个素数通过形参指针传回主函数。

  请改正函数fun中指定部位的错误, 使它能得出正确的结果。

  注意: 不要改动main函数, 不得增行或删行, 也不得更改程序的结构!

  给定源程序:

  #include

  #include

  void fun(int a,int *b,int *c)

  {int i,j,d,y;

  for(i=3;i<=a/2;i=i+2) {

  /**************found**************/

  Y=1;

  for(j=2;j<=sqrt((double)i);j++)

  if(i%j==0) y=0;

  if(y==1) {

  /**************found**************/

  d==a-i;

  for(j=2;j<=sqrt((double)d);j++)

  if(d%j==0) y=0;

  if(y==1)

  { *b=i; *c=d;}

  }

  }

  }

  main()

  {int a,b,c;

  do

  {printf("\nInput a: "); scanf("%d",&a);}

  while(a%2);

  fun(a,&b,&c);

  printf("\n\n%d = %d + %d\n",a,b,c);

  }

  解题答案:

  /**************found**************/

  y=1;

  /**************found**************/

  d=a-i;

  ******************************************

[NextPage]   三、程序题:请编写函数fun, 它的功能是:计算并输出n(包括n)以内能被5或9整除的所有自然数的倒数之和。

  例如,在主函数中从键盘给n输入20后, 输出为: s=0.583333。

  注意: 要求n的值不大于100。

  部分源程序在文件PROG1.C中。

  请勿改动主函数main和其他函数中的任何内容, 仅在函数fun的花括号中填入

  你编写的若干语句。

  给定源程序:

  #include

  double fun(int n)

  {

  }

  NONO()

  {/* 请在此函数内打开文件,输入测试数据,调用 fun 函数,输出数据,关闭文件。 */

  FILE *rf, *wf ; int n, i ; double s ;

  rf = fopen("in.dat","r");

  wf = fopen("out.dat","w");

  for(i = 0 ; i < 10 ; i++) {

  fscanf(rf, "%d", &n);

  s = fun(n);

  fprintf(wf, "%lf\n", s);

  }

  fclose(rf); fclose(wf);

  }

  main()

  {int n; double s;

  printf("\nInput n: "); scanf("%d",&n);

  s=fun(n);

  printf("\n\ns=%f\n",s);

  NONO();

  }

  参考答案:

  double fun(int n)

  {

  int i;

  double sum=0.0;

  for(i=1; i<=n; i++)

  if(i%5 == 0 || i%9 == 0) /* 被5或9整除 */

  sum+=1.0/i;

  return sum;

  }

广告合作:400-664-0084 全国热线:400-664-0084
Copyright 2010 - 2017 www.my8848.com 珠峰网 粤ICP备15066211号
珠峰网 版权所有 All Rights Reserved