国家二级(C语言)机试模拟试卷1006
程序填空题
1.使用VC++2010打开考生文件夹下blankl中的解决方案。此解决方案的项目中包含一个源程序文件blankl.c。在此程序中,函数fun()的功能是计算N×N矩阵的主对角线元素和反向对角线元素之和,并将其作为函数值返回。要求先累加主对角线元素中的值,再累加反向对角线元素中的值。
例如,若N=3,有下列矩阵:
1 2 3
4 5 6
7 8 9
首先累加1、5、9,然后累加3、5、7,函数返回值为30。
请在程序的下划线处填入正确的内容并将下划线删除,使程序得出正确的结果。
注意:部分源程序给出如下。
不得增行或删行,也不得更改程序的结构!
试题程序:
#include <stdio.h>
#define N 4
fun(int t[][N],int n)
{
int i,sum;
/*********found*********/
【1】;
for(i=0;i<n;i++)
/*********found*********/
sum+=【2】;
for(i=0;i<n;i++)
/*********found*********/
sum+=t[i][n-i-【3】];
return sum;
}
main()
{
int i,j,t[][N]={21,2,13,24,25,16,47,38,29,11,32,54,42,21,3,10};
printf(\\
(1)sum=0 (2)t[i][i] (3)1
解析:填空1:变量sum用来存储数组对角线元素的和,并将其初始化为0。故空1处应该填0。
填空2:主对角线元素的行下标和列下标是相同的,故空2处应该填t[i][i]。
填空3:对于反向对角线元素的行和列的下标,它们的关系是相加后和为n-1,故空3处应该填1。
程序修改题
2.使用VC++2010打开考生文件夹下modil中的解决方案。此解决方案的项目中包含一个源程序文件modil.c。在此程序中,函数fun()和funx()的功能是用二分法求方程2x3-4x2+3x-6=0的一个根,并要求绝对误差不超过0.001。
例如,若给m输入-100,为n输入90,则函数求得的一个根为2.000。
请改正程序中的错误,使它能得出正确的结果。
注意:不要改动main()函数,不得增行或删行,也不得更改程序的结构!
试题程序:
#include <stdio.h>
#include <math.h>
double funx(double x)
{
return(2*x*x*x-4*x*x+3*x-6);
}
double fun(double m,double n)
{
/*********found*********/
int r;
r=(m+n)/2;
/*********found*********/
while(fabs(n-m)<0.001)
{
if(funx(r)*funx(n)<0)
m=r;
else
n=r:
r=(m+n)/2;
}
return r;
}
main()
{
double m,n,rOOt;
printf(\\
(1)double r;
(2)while(fabs(n-m)>0.001)
解析:(1)根据程序可以发现r=(m+n)/2,而m和n都是double型的。根据题意可知,变量r需要定义为double型。
(2)绝对误差不超过0.001,所以循环条件应为fabs(n-m)>0.001。
程序设计题
3.使用VC++2010打开考生文件夹下progl中的解决方案。此解决方案的项目中包含一个源程序文件progl.c。在此程序中,规定输入的字符串中只包含字母和“*”。编写函数fun(),其功能是除了字符串前导和尾部的“*”外,将字符串中其他的“*”全部删除。形参h指向字符串中第一个字母,形参p指向字符串中最后一个字母。在编写函数时,不得使用C语言提供的字符串函数。
例如,若字符串中的内容为“****A*BC*DEF*G********”,删除后,字符串中的内容应当是“****ABCDEFG********”。
注意:部分源程序给出如下。
请勿改动主函数main()和其他函数中的任何内容,仅在函数fun()的花括号中填入你编写的若干语句。
试题程序:
#include <stdio.h>
#include <conio.h>
#include <string.h>
void fun(char *a,char *h,char *p)
{
}
main()
{
char s[81],*t,*f;
printf(\\
void fun(char *a,char *h,char *p)
{
int i=0;
char *q=a;
/*将前导“*”保存到a中*/
while(q<h)
{
a[i]=*q;q++;i++;
}
/*继续遍历数组*/
while(q<p){
if(*q!=’*’)
{
/*如果不是“*”,则保存到a中*/
a[i]=*q;i++;
}
q++;
}
/*将末尾“*”保存到a中*/
while(*q)
{
a[i]=*q;i++;q++;
}
a[i]=’\0’;
}
解析:本题的重点是选择好判断条件。首先需要判断前导“*”的结束,然后判断是否指向最后一个字母,最后补充尾部“*”,只要思路对了即可正确解答。
本文档预览:3600字符,共3363字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载