1. 首页 > 科技

二级C语言设计题? 计算机二级c语言题库

二级C语言设计题?计算机二级c语言题库

二级c语言100套题

发一部分给你看以下,发你信箱了.

南开习题集类型:

一、替换字符。(1、3、5、7、9、27、30、73、79、91、93、95、97、99)

二、字符串左右排序和比较。(2、4、6、12、26、29、71、72、74、84、90、96、98、100)

三、正整数排序求平均值(包括将数拆散、求最大最小值)。(8、31、33、35、37、39、42、

44、46、47、48、49、50、51、52、53、54、56、58、60、61、63、65、67、69、92、94、)

四、产品五个因素的比较排列,是结构体操作问题。(11、13、15、17、19、81、83、85、87、89 )

五、素数。(14、22、28、51、80 )

六、数字排序。(10、18、)

七、其他数学计算。(16、20、36、43、55、57、59、64、66、78、86、88 )

八、数字或字符移位后的计算。(21、23、41、45、77 )

九、学生成绩,结构体问题。(24、76 )

十、字符串(单词)的倒置和删除。(25、75 )

十一、选票问题。(32、68、70、82 )

十二、出圈问题。(34 )

十三、进制转换。(38、40、62 )

1题 函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS10.DAT中。

替代关系:f(p)=p*11 mod 256 (p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果原字符的ASCII值是偶数或计算后f(p)值小于等于32,则该字符不变,否则将f(p)所对应的字符进行替代。

部分源程序已给出,原始数据文件存放的格式是:每行的宽度均小于80个字符。

请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

#include<ctype.h>

unsigned char xx[50][80];

int maxline=0;/*文章的总行数*/

int ReadDat(void)

void WriteDat(void)

void encryptChar()

{

}

void main()

{

clrscr();

if(ReadDat()){

printf("数据文件ENG.IN不能打开!\n\007");

return;

}

encryptChar();

WriteDat();

}

int ReadDat(void)

{

FILE *fp;

int i=0;

unsigned char *p;

if((fp=fopen("eng.in","r"))==NULL) return 1;

while(fgets(xx[i],80,fp)!=NULL){

p=strchr(xx[i],'\n');

if(p)*p=0;

i++;

}

maxline=i;

fclose(fp);

return 0;

}

void WriteDat(void)

{

FILE *fp;

int i;

fp=fopen("ps10.dat","w");

for(i=0;i<maxline;i++){

printf("%s\n",xx[i]);

fprintf(fp,"%s\n",xx[i]);

}

fclose(fp);

}

________________________________________

注:在ReadDat()函数中由于fgets()函数读入数据时没有读入字符串结束符'\0',因

而用while()循环在xx数组每一行未尾将换行符'\n'替换成结束符'\0'。

编写的函数如下:该函数的基本算法是——让字符指针pf指向每一行的开头然后逐一往

后移动,在移动过程中按要求进行转换。*pf%2==0用于判断是否为偶数。if()条件语

句用于控制不替代字符。

解法1:

void encryptChar()

{

int i;

char *pf;

for(i=0;i<maxline;i++) /*行循环*/

{pf=xx[i]; /*每行字符个数*/

while(*pf!=0)

{if(*pf%2==0||*pf*11%256<32)

{pf++;continue;}

*pf=*pf*11%256;

pf++;

}

}

}

解法2:

void encryptChar()

{

int i,j,t;

for(i=0;i<maxline;i++)

{

for(j=0;j<strlen(xx[i]);j++)

{

t=xx[i][j]*11%256;

if(t<=32 || xx[i][j]%2==0) continue;

xx[i][j]=t;

}

}

}

2题 函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(第行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果xx输出到文件out.dat中。

条件:从字符串中间一分为二,左边部分按字符的ASCII值升序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加处理,字符仍放在原位置上。

例如:位置 0 1 2 3 4 5 6 7 8

源字符串 d c b a h g f e

4 3 2 1 9 8 7 6 5

则处理后字符串 h g f e a b c d

8 7 6 5 9 1 2 3 4

部分源程序已给出。

请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

char xx[20][80];

void jsSort()

{

}

void main()

{

readDat();

jsSort();

writeDat();

}

readDat()

{

FILE *in;

int i=0;

char *p;

in=fopen("in.dat","r");

while(i<20&&fgets(xx[i],80,in)!=NULL){

p=strchr(xx[i],'\n');

if(p)*p=0;

i++;

}

fclose(in);

}

writeDat()

{

FILE *out();

int i;

clrscr();

out=fopen("out.dat","w");

for(i=0;i<20;i++){

printf(\"%s\n",xx[i]);

fprintf(out,"%s\n",xx[i]);

}

fclose(out);

}

________________________________________

注:先采用冒泡法对左边部分进行升序排序,然后将排序后的左半与右半按对应位进行

调换。

void jsSort()

{

int i,strl,half,j,k;

char ch;

for(i=0;i<20;i++) /*行循环*/

{strl=strlen(xx[i]); /*每行长度*/

half=strl/2;

for(j=0;j<half-1;j++) /*每行的第j个位置*/

for(k=j+1;k<half;k++)

if(xx[i][j]>xx[i][k])

{ch=xx[i][j]; /*每次将最小数赋给xx[i][j]*/

xx[i][j]=xx[i][k];

xx[i][k]=ch;

}

for(j=half-1,k=strl-1;j>=0;j--,k--)

{ch=xx[i][j];

xx[i][j]=xx[i][k];

xx[i][k]=ch;

}

}

}

void jsSort()

{

int i,j,k,strl;

char ch;

for(i=0;i<20;i++)

{

strl=strlen(xx[i]);

for(j=0;j<strl/2;j++)

for(k=j+1;k<strl/2;k++)

if(xx[i][j]>xx[i][k])

{

ch=xx[i][j];

xx[i][j]=xx[i][k];

xx[i][k]=ch;

}

for(j=0;j<strl/2;j++)

{

ch=xx[i][j];

xx[i][j]=xx[i][(strl+1)/2+j];

xx[i][(strl+1)/2+j]=ch;

}

}

}

3题 函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS8.DAT中。

替代关系:f(p)=p*11 mod 256 (p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果原字符是小写字母或计算后f(p)值小于等于32,则该字符不变,否则将f(p)所对应的字符进行替代。

部分源程序已给出。原始数据文件存放的格式是:每行的宽度均小于80个字符。

请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

#include<ctype.h>

unsigned char xx[50][80];

int maxline=0;/*文章的总行数*/

int ReadDat(void)

void WriteDat(void)

void encryptChar()

{

}

void main()

{

clrscr();

if(ReadDat()){

printf("数据文件ENG.IN不能打开!\n\007");

return;

}

encryptChar();

WriteDat();

}

int ReadDat(void)

{

FILE *fp;

int i=0;

unsigned char *p;

if((fp=fopen("eng.in","r"))==NULL) return 1;

while(fgets(xx[i],80,fp)!=NULL){

p=strchr(xx[i],'\n');

if(p)*p=0;

i++;

}

maxline=i;

fclose(fp);

return 0;

}

void WriteDat(void)

{

FILE *fp;

int i;

fp=fopen("ps8.dat","w");

for(i=0;i<maxline;i++){

printf("%s\n",xx[i]);

fprintf(fp,"%s\n",xx[i]);

}

fclose(fp);

}

________________________________________

注:与题1相似。

void encryptchar()

{

int i;

char *pf;

for(i=0;i<maxline;i++)

{pf=xx[i];

while(*pf!=0)

{if((*pf>='a'&&*pf<='z')||*pf*11%256<32)

{pf++;continue;}

*pf=*pf*11%256;

pf++;

}

}

}

void encryptChar()

{

int i,j,t;

for(i=0;i<maxline;i++)

{

for(j=0;j<strlen(xx[i]);j++)

{

t=xx[i][j]*11%256;

if(t<=32 || (xx[i][j]>='a' && xx[i][j]<='z')) continue;

xx[i][j]=t;

}

}

}

4题 函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(第行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果xx输出到文件out.dat中。

条件:从字符串中间一分为二,左边部分按字符的ASCII值降序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加处理,字符仍放在原位置上。

例如:位置 0 1 2 3 4 5 6 7 8

源字符串 a b c d h g f e

1 2 3 4 9 8 7 6 5

则处理后字符串 h g f e d c b a

8 7 6 5 9 4 3 2 1

部分源程序已给出。

请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

char xx[20][80];

void jsSort()

{

}

void main()

{

readDat();

jsSort();

writeDat();

}

readDat()

{

FILE *in;

int i=0;

char *p;

in=fopen("in.dat","r");

while(i<20&&fgets(xx[i],80,in)!=NULL){

p=strchr(xx[i],'\n');

if(p)*p=0;

i++;

}

fclose(in);

}

writeDat()

{

FILE *out();

int i;

clrscr();

out=fopen("out.dat","w");

for(i=0;i<20;i++){

printf("%s\n",xx[i]);

fprintf(out,"%s\n",xx[i]);

}

fclose(out);

}

________________________________________

注:该题采用插入法实行降序排序,其它与题2相似。

void jsSort()

{

int i,strl,half,j,k;

char ch;

for(i=0;i<20;i++)

{strl=strlen(xx[i]);

half=strl/2;

for(j=1;j<half;j++)

{ch=x[i][j];

k=j-1;

while((k>=0)&&(ch>xx[i][k]))

{xx[i][k+1]=xx[i][k];

k--;

}

xx[i][k+1]=ch;

}

for(j=half-1,k=strl-1;j>=0;j--,k--)

{ch=xx[i][j];

xx[i][j]=xx[i][k];

xx[i][k]=ch;

}

}

}

void jsSort()

{

int i,j,k,strl;

char ch;

for(i=0;i<20;i++)

{

strl=strlen(xx[i]);

for(j=0;j<strl/2;j++)

for(k=j+1;k<strl/2;k++)

if(xx[i][j]<xx[i][k])

{

ch=xx[i][j];

xx[i][j]=xx[i][k];

xx[i][k]=ch;

计算机二级c语言程序设计有哪些题型,考什么内容?

计算机二级有国考和省考两种,我只说国考,省考是省教育考试院组织的,每个省不一样。

全国计算机二级C语言程序设计包括40个单选题(每题一分)和三道操作题(60分)。

单选题中1~10题为二级公共基础知识,单选题的11~40题是C语言的内容。

操作题包括程序填空(18分)、程序改错(18分)和编程题(24分)各一题。

程序填空是将一个完整的程序,扣掉两到三处,让考生将它填写完整。由于每位考生具体抽到的题目不同,程序填空有2到3个空要填。

程序改错也是一个完整的程序,其中有2~3处错误要求考生将他们改正。程序改错题会提示每一处错误在第几行,在那一行的上一行有********found********标识。

编程题是要求考生编写一个程序,然后运行出题干要求的结果。题目中主函数main()会完整给出,在主函数中将调用fun()函数,fun函数由考生自己编写。编程题以运行结果给分,所编写完成后必须运行,否则没分。

二级C语言程序设计考试涉及公共基础知识和C语言两块。公共基础知识内容包括数据结构与算法、程序设计基础、软件工程基础、数据库设计基础四部分。考10个单选每个1分。

C语言有基础知识(C语言概述、常量与变量、数据类型、运算符和表达式),编程三大结构(顺序结构、选择结构、循环结构),数组、函数和指针,其他内容(预处理命令、结构体和共用体、位运算、文件)四大部分内容。重点是第二、三部分。

二级C语言程序设计题。怎么评分?

等级考试机试的玄机是计算机改分。也就是说,上机成绩不是由人评改的。

等级考试的上机考试是分批进行的,在相邻两批考生之间,有监考人员做“收分”工作,即改分。也就是说,当你考完机试后,你的上机成绩就已经出来了,只是我们不知道结果罢了。当然,监考人员也不知道,因为最后分数是加密的。

另外,改分程序在评改你的上机成绩后,将你的考试目录中的所有内容全部删除!

现在,我们就“计算机改分”这个问题做如下讨论:

1、计算机改分实质上就是评分软件改你上机时所设计的软件--------软件改软件!

2、目前,计算机智能的水平还是很低的,不可能对编程思想进行分析!

3、一个程序题目可以有不止一种编程方法,绝无标准答案可言!

综上:机试的评分标准绝对不可能是“按步骤给分”!

实质上,上机编程题目都必将生成一个文件!

所以,评分程序是按照最终生成的文件给分的!

由上述结论可以推出如下事实:

1、只要考生能生成最终答案文件,均可得分!

2、很多最终答案文件只有少数若干行数据,分数由正确答案的行数决定!比如:《全国计算机等级考试上机考试习题集(三级C语言程序设计)》(南开大学出版社)第21题,要求用迭代方法计算cos(x)-x=0的一个近似根,其答案是0.739085,最终要求生成的文件OUT17.DAT中只有一行数据。有这个文件,并且该文件只有一行数据0.739085的话,就可以得到100分!无所谓你是否编写程序了!!!当然,有多行答案的文件的文件格式是由程序中的输出部分决定的(而这个部分是不允许考生修改的!),考生必须能够看懂输出程序段的输出格式,否则会事得其反!

2020年全国计算机等级考试二级c语言上机精选题库(共70套)

去百度文库,查看完整内容>

内容来自用户:夜宿山寺

2020年全国计算机等级考试二级c语言上机精选题库(共70套)

第1套

(填空题)给定程序中,函数fun的功能是:将行参指针所指结构体数组中的三个元素按num成员进行升序排列。请勿改动主函数main和其他函数中的任何内容,仅在横线上填入所编写的若干表达式或语句。

#include

typedef struct

{

int num;

char name[10];

} PERSON;

void fun(PERSON ___1___)

{

___2___ temp;

if (std[0].num > std[1].num)

{

temp = std[0];

std[0] = std[1];

std[1] = temp;

}

if (std[0].num > std[2].num)

{

temp = std[0];

std[0] = std[2];

std[2] = temp;

}

if (std[1].num > std[2].num)

{

temp = std[1];

std[1] = std[2];

std[2] = temp;

}

}

main()

{

PERSON std[] = {5, "Zhanghu", 2, "WangLi", 6, "LinMin"};

int i;

fun(___3___);

printf("\nThe result is :\n");

for (i=0; i<3; i++)

printf("%d,%s\n", std[i].num, std[i].name);

}

(改错题)下列给定程序中,函数fun的功能是:求k!(k〈13〉,所求阶乘的值作为函数值返回。例如:若k=10,则应输出3628800。请改正程序中的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!

#include

#include

long fun(int k)

{<