最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 正文

国家二级C语言编程

来源:懂视网 责编:小OO 时间:2024-12-06 02:41:54
文档

国家二级C语言编程

1、请编一个函数fun,它的功能是:根据以下公式求π的值(要求满足精度0.0005,即,某项小于0.0005时停止迭代)。程序运行后,如果输入精度0.0005,则程序输出多少。注意:部分源程序存在PROG1.C中,请勿改动主函数和其他函数中的内容,仅在函数fun的指定的部位填入你编写的若干语句。试题源程序如下:#include <stdio.h>。#include <math.h>。double fun(double eps)。{;};main();{;double x。printf(";Input eps:";)。scanf(";%lf";,&x)。
推荐度:
导读1、请编一个函数fun,它的功能是:根据以下公式求π的值(要求满足精度0.0005,即,某项小于0.0005时停止迭代)。程序运行后,如果输入精度0.0005,则程序输出多少。注意:部分源程序存在PROG1.C中,请勿改动主函数和其他函数中的内容,仅在函数fun的指定的部位填入你编写的若干语句。试题源程序如下:#include <stdio.h>。#include <math.h>。double fun(double eps)。{;};main();{;double x。printf(";Input eps:";)。scanf(";%lf";,&x)。

计算机考试历年二级C语言上机编程题分析

1、请编一个函数fun,它的功能是:根据以下公式求π的值(要求满足精度0.0005,即,某项小于0.0005时停止迭代):

程序运行后,如果输入精度0.0005,则程序输出多少。注意:部分源程序存在PROG1.C中,请勿改动主函数和其他函数中的内容,仅在函数fun的指定的部位填入你编写的若干语句。试题源程序如下:

#include <stdio.h>

#include <math.h>

double fun(double eps)

{

}

main()

{

double x;

printf("Input eps:");

scanf("%lf",&x);

printf("\neps=%lf, PI=%lf\n",x,fun(x));

}

分析:(1)本题所用基本算法应为累加。假设累加值放在变量s中,累加项放在变量t中,累加操作由语句s=s+t;来实现。 (2)若称 为第1累加项,则其前的1为第0累加项,其后的一项为第2累加项,按给定的公式可知,从第1累加项开始,后一项的累加项是前一项的值乘以 。所以当前的累加项应当是:t=t*n/(2.0*n+1.0)。表达式右边的t中是前一项的值,表达式左边的t为当前的每累加累加项。请注意,不要写成:t*n/(2*n+1)而进行整除。(3)若第0累加项的1作为s的初值,语句:s=s+t;执行n次,就把第1到第n项累加到了s中。每进行一次累加,n值增1。(4)把以上操作放在循环中。按本题规定,当某项小于eps(0.0005)时停止迭代,因此若用while循环,可用t>=eps作为控制循环进行的条件:while( t>=eps ){ s+=t; n++; t=t*n/(2.0*n+1); }

(5)注意应给所用变量赋适当的初值。(6)退出循环后,函数的返回值应是:2*s。

2、请编一个函数fun,其中n所指存储单元中存放了数组中元素的个数。函数的功能是:删除所有值为y的元素。已在主函数中给数组元素赋值,y的值由主函数通过键盘读入。注意:部分源程序存在PROG1.C中,请勿改动主函数和其他函数中的内容,仅在函数fun的指定的部位填入你编写的若干语句。试题源程序如下:

#include <stdio.h>

#define M 20

void fun(int bb[],int *n, int y)

{

}

main()

{

int aa[M]={1,2,3,3,2,1,1,2,3,4,5,4,3,2,1}, n=15, y, k;

printf("The original data is: \n");

for(k=0; k<n; k++ ) printf("=",aa[k]);

printf("\nEnter a number to deleted: ");

scanf("%d",&y);

fun(aa, &n, y);

printf("The data after deleted %d: \n",y);

for(k=0; k<n; k++ ) printf("=",aa[k]);

printf("\n\n");

}

分析:(1)本题的基本算法是查找和删除。(2)若循环控制变量是i,通过for循环逐个检查元素中的值,把数组元素中不等于y的值从头开始重新放入bb所指的数组中。用i作为下标,逐个引用数组元素;用i作为下标,把不等于y的元素中的值逐一重新放入bb所指的数组中。这一操作可用以下语句来实现:if(bb[i]!=y)bb[j++]=bb[i];(3)因为已删除了与y值相等的元素,因此,数组中数据的个数已经改变;所以循环结束后,需要重新给n所指变量赋值。退出循环后,变量j中存放的是删除后数组中数据的个数,通过语句*n=j;把它赋给n所指变量即可。(4)主函数中输出aa数组中原有的数据,和删除后的数据。考生可以对照所编函数是否正确。

3.请编写一个函数void fun(char m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m的k个素数存入xx所指的数组中。例如,若输入17和5,则应输出:19,23,29,31,37。注意:部分源程序存在PROG1.C中,请勿改动主函数和其他函数中的内容,仅在函数fun的指定的部位填入你编写的若干语句。试题源程序如下:

#include <stdio.h>

void fun(int m, int k, int xx[])

{

}

main()

{

int m, n, zz[100];

printf("\nPlease enter two integers(m & n): ");

scanf("%d%d",&m,&n);

fun(m, n, zz);

for(m=0; m<n; m++) printf("%d ",zz[m]);

printf("\n\n");

}

分析:(1)本题的基本算法是求素数。假设有整数i,若i不能被2到i之间的任意一个数除尽,则i就是素数;若一旦能被某个数除尽就不是素数。(2)以下是求i是否为素数的基本算法:变量ok用作i是素数的标志,ok为1,则i是素数。ok=1;for(p=2; p<i/2; p++)if( i%p==0){ ok=0; break; }if(ok)……(3)本题要求把大于m的k个素数存入xx所指的数组中。所以,i的值应大于m;取大于m的值逐一进行判断,若是素数就放入xx所指数组中。把以上语句放入一个循环中:for( i=m+1,j=0; ? ; i++ ) { ok=1;for(p=2; p<=i/2; p++)if( i%p==0 ){ ok=0; break; }if (ok) { xx[j]=i;j++; } }

此处,变量i统计存入数组中元素的个数,同时作为下标。(4)按本题的要求,外循环结束的条件应当是:j<k(j的值从0到k-1)。只要求得了k个素数,就可退出循环。因此在?处应填入j<k。

文档

国家二级C语言编程

1、请编一个函数fun,它的功能是:根据以下公式求π的值(要求满足精度0.0005,即,某项小于0.0005时停止迭代)。程序运行后,如果输入精度0.0005,则程序输出多少。注意:部分源程序存在PROG1.C中,请勿改动主函数和其他函数中的内容,仅在函数fun的指定的部位填入你编写的若干语句。试题源程序如下:#include <stdio.h>。#include <math.h>。double fun(double eps)。{;};main();{;double x。printf(";Input eps:";)。scanf(";%lf";,&x)。
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top