国家二级C语言机试(操作题)模拟试卷527
程序填空题
1.程序通过定义学生结构体变量,存储了学生的学号、姓名和三门课的成绩。所有学生数据均以二进制方式输出到文件中。函数fun的功能是重写形参flename所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其他学生的数据不变。
请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。
注意:部分源程序在文件BLANK1.C中。
不得增行或删行,也不得更改程序的结构!
试题程序:
#inclucle<stctio.h>
#define N 5
typeclef struct student{
long sno;
char name[10];
float score[3];
} STU;
void fun(char * filename,STU n)
{FTLE*fp;
/*********found*********/
fp=fopen(【1】,\\
(1)filename
(2)fp
(3)fp
解析:填空1:本空是对文本文件的打开,filename所指的文件中的最后数据要进行重写,因此首先是要打开,因而本空填写filename。
填空2:fseek功能是重定位流上的文件指针。
用法:int fseek(FILE*stream,long offset,int from-where);本空应该填写fp。
填空3:因为题目中要对所有学生数据均以二进制方式输出到文件中,因此本空填写fp。
知识点讲解:
函数名:fseek
功能:重定位流上的文件指针。
用法:int fseek(FILE*stream,long offset,intfromwhere)。
描述:函数设置文件指针stream的位置。如果执行成功,stream将指向以fromwhere为基准(从文件的哪里开始偏移)、偏移offset个字节的位置。正数表示正向偏移,负数表示负向偏移。如果执行失败(比如offset超过文件自身大小),则不改变stream指向的位置。
返回值:成功,返回0;否则返回非0值。
程序修改题
2.下列给定程序中函数Creatlink的功能是:创建带头结点的单向链表,并为各结点数据域赋0到m-1的值。
请改正函数Creatlink中指定部位的错误,使它能得出正确的结果。
注意:部分源程序在文件MODI1.C中,不要改动main函数,不得增行或删行,也不得更改程序的结构!
试题程序:
#include < stdio .h >
#include < stdlib.h >
typedef struct aa
{ int data;
struct aa * next f
} NODE;
NODE* Creatlink (int n. int m)
{ NODE*h=NULL, *p, *s;
int i;
/*********found*********/
p = (NODE)malloc (sizeof (NODE)) ;
h =p;
p一> next = NULL;
for(i=1; i< =nf i++)
{ s = (NODE * ) malloc ( sizeof
s 一> data = rand () % m;
s 一>next =p 一>next;
p 一>next =s; p =p 一>next;
/*********found*********/
return p;
}
outlink (NODE* h)
{ NODE *p;
p =h 一> next;
printf \\
(1)p=(NODE*)malloc(sizeof( NODE));
(2)return h;
解析:(1)由变量定义可知p为指向结点的指针。指向刚分配的结构指针,所以应改为p=(NODE*)malloc( sizeof(NODE)).
(2)在动态分配内存的下一行语句是,使用临时结构指针变量h保存p指针的初始位置,最后返回不能使用p,是因为p的位置已经发生了变化,所以应改为return h。
程序设计题
3.请编写函数fun,该函数的功能是:
统计一行字符串中单词的个数,作为函数值返回。字符串在主函数中输入,规定所有单词由小写字母组成,单词之间有若干个空格隔开,一行的开始没有空格。
注意:部分源程序在文件PROG1.C中。
请勿改动main函数和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
试题程序:
#include < string.h >
#include < stdio .h >
#define N 80
int fun (char *s)
{
}
void main ()
{
FILE *wf;
char line[ N] ;
int num=0;
printf (\\
int fun(char*s)
{
int i,j=0;
for(i=0;s[i]!=’\0’;i++)
if(s[i]!=’’&&(s[i+1]==’’||
s[i+1]==’\0’))
/*如果一个字母的下一个字符为空格或者结束标记,则表示一个单词结束*/
j++;
return j; /*返回单词个数*/
}
解析:要判断单词的个数,首先想到的是程序怎样识别出一个单词,如果一个字母的下一个字符为空格或者结束标记,则表示一个单词结束,因此程序使用for循环语句遍历整个字符串,用if条件语句判断当前字符是否表示一个单词的结束,如果当前字符表示一个单词结束,则存放单词个数的变量加1,最后返回单词的个数。
本文档预览:3600字符,共3222字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载