C语言程序设计省二级考试题编程.docx
- 文档编号:23239
- 上传时间:2022-10-01
- 格式:DOCX
- 页数:58
- 大小:27.09KB
C语言程序设计省二级考试题编程.docx
《C语言程序设计省二级考试题编程.docx》由会员分享,可在线阅读,更多相关《C语言程序设计省二级考试题编程.docx(58页珍藏版)》请在冰豆网上搜索。
C语言程序设计省二级考试题编程
文件题:
1、已知在文本文件20075.txt中共有500个记录,
每个记录是用以下格式表示的5项数据(各数据间以空格分开)
(从网络课件中下载素材文件):
学号 姓名 机试成绩 笔试成绩 平时成绩
nnnnnnnnn cccccc nn nn nn
(说明:
n表示整型;c表示字符型;
n的个数表示数据位数,例如nn表示两位整数,
c的个数表示字符位数)求出前400人的机试的平均成绩。
*/
#include
#include
main()
{
FILE *fp;
char xh[10],name[7];
int i,js,bs,pscj;
double sum=0,average;
fp=fopen("20075.txt","r");
if(fp!
=NULL)
{
for(i=1;i<=400;i++)
{
fscanf(fp,"%s%s%d%d%d",xh,name,&js,&bs,&pscj);
sum+=js;
}
average=sum/400;
printf("average=%.2lf\n",average);
fclose(fp);
}
else
{
printf("文件打开失败!
\n");
exit(0);
}
}
/*
average=91.56
Press any key to continue
*/
2、已知在文本文件20071.txt中共有600个记录,
每个记录是一个用xx.x格式表示的实数,
编写程序统计出记录中所有
大于等于60的数据个数(使用循环结构实现)
*/
#include
#include
main()
{
FILE *fp;
int i;
double score;
int count=0;
fp=fopen("20071.txt","r");
if(fp!
=NULL)
{
for(i=1;i<=600;i++)
{
fscanf(fp,"%lf",&score);
if(score>=60)
count++;
}
fclose(fp);
printf(">=60的人数为%d\n",count);
}
else
{
printf("文件打开失败!
\n");
exit(0);
}
}
/*
>=60的人数为513
Press any key to continue
*/
3、/*
已知在文本文件{<20081.txt>}中共有600个记录,
每个记录是一个用"xx.x"格式表示的实数,
编程将该文件中的
全部数据原样复制一份到文本文件20082.txt中。
*/
#include
#include
main()
{
FILE *f20081,*f20082;
double score;
int i;
f20081=fopen("20081.txt","r");
f20082=fopen("20082.txt","w");
if(f20081!
=NULL&&f20082!
=NULL)
{
while( fscanf(f20081,"%lf",&score)!
=EOF)
{
fprintf(f20082,"%4.1lf\n",score);
}
fclose(f20081);
fclose(f20082);
printf("文件复制成功!
\n");
}
else
{
printf("20081.txt未打开或20082.txt未打开!
\n");
exit(0);
}
}
4、
#include
#include
main()
{
FILE *f20083,*f20084,*f20085;
double score;
f20083=fopen("20083.txt","r");
f20084=fopen("20084.txt","r");
f20085=fopen("20085.txt","w");
if(f20083!
=NULL&&f20084!
=NULL&&f20085!
=NULL)
{
while( fscanf(f20083,"%lf",&score)!
=EOF)
{
fprintf(f20085,"%4.1lf\n",score);
}
while( fscanf(f20084,"%lf",&score)!
=EOF)
{
fprintf(f20085,"%4.1lf\n",score);
}
fclose(f20083);
fclose(f20084);
fclose(f20085); printf("两个文件合并成功,请检查20085.txt是否存在!
\n");
}
else
{
printf("20083.txt或20084.txt或20085.txt未打开!
\n");
exit(0);
}
}
5、/*
已知在文本文件{
每个记录是一个用"xx.xx"格式表示的实数,
编程求出文件中每两个相邻数中的小值的和。
注:
每两个相邻数的含义是:
第i个数与第i+1个数称为是两个相邻数。
*/
#include
main()
{
FILE *fp;
double sum=0,score,pre;
fp=fopen("s20092.txt","r");
if(fp!
=NULL)
{
fscanf(fp,"%lf",&pre);
while( fscanf(fp,"%lf",&score)!
=EOF)
{
if(pre { sum+=pre; } else { sum+=score; } pre=score; } fclose(fp); printf("sum=%.2lf\n",sum); } else { printf("s20092.txt打开失败! \n"); exit(0); } } /* sum=24279.36 Press any key to continue */ 6、 /* 已知在文本文件{<20074.txt>}中共有600个记录, 每个记录是一个用"xx.xx"格式表示的实数, 编程求出文件中其值 小于50的最大实数首次出现是第几个记录。 */ #include #include main() { FILE *fp; double score,max; int pos=0,result; fp=fopen("20074.txt","r"); if(fp! =NULL) { /*找出小于50的第一条记录,并把数据赋值给max*/ while( fscanf(fp,"%lf",&score)! =EOF) { pos++; if(score<50) { max=score; break; } } fclose(fp); } else { exit(0); } pos=0; fp=fopen("20074.txt","r"); if(fp! =NULL) { while( fscanf(fp,"%lf",&score)! =EOF) { pos++; if(score>max&&score<50) { max=score; result=pos; } } fclose(fp); } else { exit(0); } printf("小于50的最大实数首次出现是第%d个记录\n",result); 一维数组: 1#include main() { inti,j,t; inta[10]={11,33,56,67,25,45,43,54,69,89}; printf("冒泡法排序前: \n"); for(i=0;i<10;i++) printf("%3d",a[i]); printf("\n"); /*冒泡法排序*/ for(i=0;i<10-1;i++) { for(j=0;j<10-1-i;j++) {
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言程序设计 二级 考试题 编程