- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
模拟试题改
模拟试题
1. 编程题
请编写函数fun(),该函数的功能是:移动一维数组中的内容,若数组中有n个整数,要求把下标从p到n-1(p≤n-1)的数组元素平移到数组的前面。
例如,一维数组中的原始内容为1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,p的值为6。移动后,一维数组中的内容应为7,8,9,10,10,11,12,13,14,15,1,2,3,4,5,6。
注意:部分源程序给出如下。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
试题程序:
#include stdio.h
#define N 80
void fun(int *w, int p, int n)
{
}
main()
{
int a[N]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
int i, p, n=15;
printf(The original data:\n);
for(i=0;in;i++)
printf(%3d,a[i]);
printf(\n\nEnter p: );
scanf(%d,p);
fun(a,p,n);
printf(\nThe data after moving:\n);
for(i=0;in;i++)
printf(%3d,a[i]);
printf(\n\n);
}
答案及评析:
void fun(int *w, int p, int n)
{
int i,j,t;
for(i=p;i=n-1;i++) /*循环右移n-p次*/
{t=w[n-1];
for(j=n-2;j=0;j--) /*实现循环右移*/
w[j+1]=w[j];
w[0]=t;
}
}
【解析】本题采用循环右移的算法。和我们在前面分析的稍有不同的是,一个是整型数组,一个是字符型数组。
2. 编程题
学生的记录由学号和成绩组成,N名学生的数据已在主函数中放入结构体数组s中,请编写函数fun(),它的功能是:把分数最低的学生数据放在h所指的数组中。注意:分数低的学生可能不只一个,函数返回分数最低学生的人数。
注意:部分源程序给出如下。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
试题程序:
#include stdio.h
#define N 16
typedef struct
{ char num[10];
int s ;
}STREC;
int fun (STREC *a, STREC *b)
{
}
main ()
{
STREC s[N]={{GA005,82},{GA003,75},{GA002,85},{GA004,78},
{GA001,95},{GA007,62},{GA008,60},{GA006,85},
{GA015,83},{GA013,94},{GA012,78},{GA014,97},
{GA011,60},{GA017,65},{GA018,60},{GA016,74}};
STREC h[N];
int i, n;
FILE *out;
n=fun(s,h);
printf(The %d lowest score :\n,n);
for (i=0; in; i++)
printf(%s %4d\n,h[i].num,h[i].s); /*输出最低分学生的学号和成绩*/
printf(\n);
out=fopen(out19.dat, w);
fprintf(out, %d\n,n);
for(i=0; in; i++);
fprintf(out, %4d\n ,h[i].s);
fclose(out);
}
答案及评析:
int fun (STREC *a, STREC *b)
{
int i,j=0,min=a[0].s;
for(i=0;iN;i++)
if(mina[i].s)
min=a[i].s; /*找出最小值*/
for(i=0;iN;i++)
if(min==a[i].s)
b[j++]=a[i]; /*找出成绩与min相等的学生的记录,存入结构体b中*/
return j; /*返回最低成绩的学生人数*/
}
【解析】该程序使用循环嵌套,第1个for语句的作用
文档评论(0)