上机100题(二级C语言考试,有答案) 下载本文

内容发布更新时间 : 2024/12/23 22:50:42星期一 下面是文章的全部内容请认真阅读。

1:下列程序的功能是:将大于整数m且紧靠m的k个素数存入数组xx。请编写函数num(int m,int k,int xx[])实现函数的要求 ,最后调用函数readwriteDAT()把结果输出到文件out.dat中。

例如:若输入17,5,则应输出:19,23,29,31,37。 注意:部分源程序已给出。

请勿改动主函数main()和函数readwriteDAT()的内容。 ---------类型:素数。

void num(int m,int k,int xx[]) /*标准答案*/ {int data=m+1; int half,n=0,I; while(1)

{half=data/2;for(I=2;I<=half;I++) if(data%I==0)break; if(I>half)

{xx[n]=data;n++;} if(n>=k)break; data++; } } 或者:

void num(int m,int k,int xx[]) {int i,j,s=0;

for(i=m+1;k>0;i++) {for(j=2;j

if(i%j==0) break; /*注:素数为只能被自己和1整除的数.如果i%j等于0,说明i不是素数,跳出本层循环*/ if(i==j)

{xx[s++]=i;k--;} } } 或者:

void num(int m, int k, int xx[]) { int i=0;

for(m=m+1;k>0;m++) if(isP(m)) { xx[i++]=m; k--; } } 原程序如下:

#include #include void readwriteDAT() ;

int isP(int m) { int i ;

for(i = 2 ; i < m ; i++) if(m % i == 0) return 0 ; return 1 ; }

void num(int m,int k,int xx[]) { }

main()

{ int m, n, xx[1000] ; clrscr() ;

printf(\scanf(\num(m, n, xx) ;

for(m = 0 ; m < n ; m++) printf(\printf(\readwriteDAT() ; system(\}

void readwriteDAT()

{ int m, n, xx[1000], i ; FILE *rf, *wf ;

rf = fopen(\wf = fopen(\for(i = 0 ; i < 10 ; i++) { fscanf(rf, \num(m, n, xx) ;

for(m = 0 ; m < n ; m++) fprintf(wf, \xx[m]) ;

fprintf(wf, \}

fclose(rf) ; fclose(wf) ; }

2:已知数据文件IN.DAT中存有200个四位数, 并已调用读函数readDat()把这些数存入数组a中,请考生编制一函数jsVal(),其功能是: 如果四位数各位上的数字均是0或2或4或6或8, 则统计出满足此条件的个数cnt, 并把这些四位数按从大到小的顺序存入数组b中。最后main()函数调用写函数writeDat( )把结果cnt以及数组b中符合条件的四位数输出到OUT.DAT文件中。 注意: 部分源程序存在文件PROG1.C文件中。

程序中已定义数组: a[200], b[200], 已定义变量: cnt 请勿改动数据文件IN.DAT中的任何数据、主函数

main()、读函数readDat()和写函数writeDat()的内容 ------------------------- void jsVal() /*标准答案*/ {int bb[4];

int I,j,k,flag;

for (I=0;I<200;I++)

{bb[0]=a[I]/1000; bb[1]=a[I]00/100; bb[2]=a[I]0/10; bb[3]=a[I]; for (j=0;j<4;j++) {if (bb[j]%2==0) flag=1; else

{flag=0;break;} }

if (flag==1) { b[cnt]=a[I]; cnt++;} }

for(I=0;I

{k=b[I];b[I]=b[j];b[j]=k;} }

原程序如下:

二级C语言 第 1 页 共 68 页

#include #define MAX 200

int a[MAX], b[MAX], cnt = 0;

void jsVal() { }

void readDat() { int i ; FILE *fp ;

fp = fopen(\

for(i = 0 ; i < MAX ; i++) fscanf(fp, \&a[i]) ;

fclose(fp) ; }

void main() { int i ; readDat() ; jsVal() ;

printf(\满足条件的数=%d\\n\

for(i = 0 ; i < cnt ; i++) printf(\printf(\writeDat() ;

system(\}

writeDat() { FILE *fp ; int i ;

fp = fopen(\fprintf(fp, \

for(i = 0 ; i < cnt ; i++) fprintf(fp, \b[i]) ;

fclose(fp) ; }

3:函数READDAT()实现从文件IN.DAT中读取一篇英文文章存入到字符串数组XX中;请编制函数STROR(),其函数功能是:以行为单位把字符串中的所有小写字母O左边的字符串内容移到该串的右边存放,然后并把小写字母O删除,余下的字符串内容移到已处理字符串的左边存放.最后把已处理的字符串仍按行重新存入字符串数组XX中,最后调用函数WRITEDAT()把结果XX输出到文件OUT.DAT中.

例如:原文:You can create an index on any field. you have the correct record.

结果: n any field.You can create an index rd.yu have the crrect rec

原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格.

--------------类型:字符串(单词)的倒置和删除。 void StrOR(void) /*标准答案*/ {int I,j,k,index,strl; char ch;

for(I=0;I

for(j=0;j

{for(k=j;k

for(j=strl-1;j>=index;j--) {ch=xx[I][strl-1]; for(k=strl-1;k>0;k--) xx[I][k]=xx[I][k-1]; xx[I][0]=ch;} } }

或者:

void StrOR(void) { int i;

char a[80],*p;

for(i=0;i

{ memset(a,0,80);

memcpy(a,xx[i],p-xx[i]); strcpy(xx[i],p+1); strcat(xx[i],a);

p=strchr(xx[i],'o'); } } }

或者:

void StrOR(void) /*我的非指针解法*/ {int i,righto,j,k; char tem[80];

for(i=0;i

{k=0;righto=0;memset(tem,0,80); for(j=strlen(xx[i])-1;j>=0;j--)

{if(xx[i][j]=='o') {righto=j;break;} } for(j=righto+1;j

{if(xx[i][j]!='o') tem[k++]=xx[i][j];} strcpy(xx[i],tem); }}

或者:

注:该题要求的字符串中所有小写字母o左边的字符串内容移到该串的右边存放,即将串中“最后”一个字母o左右两侧的内容互换。题中第一个while()特环的作用是让p1指向最后一个字母'o'。第一个ctrcat()函数的作用是将p1以后的字符都放到新串t中,第二个strcat()函数的作用是将p1以前的字符连接到新串t的后面(注意:在些之前要让p1所指的单元成为p1前面字符串的结束位置*p1='\\0')。这时完成左右互换。最后一个

while()循环的作用是删除新串中的所有小写字母'o',采用的删除方法是不是'o'的字母一律留下,否则不留(即相当于删除。)

void StrOR(void) {int i;

char *p1,*p2,t[80]; for(i=0;i

二级C语言 第 2 页 共 68 页

{t[0]='\\0';p2=xx[i]; while(*p2)

{if(*p2=='o') p1=p2; p2++;}

strcat(t,p1+1);

*p1='\\0';strcat(t,xx[i]); p1=xx[i];p2=t; while(*p2)

{if(*p2!='o') *p1++=*p2; p2++; }

*p1='\\0'; }}

或者:

注:该题的主要算法是先让两字符指针都指向串尾,然后使一指针(p1)往前移动,当出现不是字母时则表示在p1+1与p2之间是一个单词,并将该单词存入一变量(t1),最后 将t1连接到新串中(t);接着再往前找第二个单词,依次类推直到字符串头。由此可知新串就是原串中各单词的倒排。

void Str0L(void) {

int i,k;

char *p1,*p2;

char t[80],t1[80];

for(i=0;i

{p2=p1=strchr(xx[i],'\\0')-'\\0'; t[0]=t1[0]='\\0'; k=1;

while(k) {

while(isalpha(*p1)==0&&p1!=xx[i]) {p1--;p2=p1;} while(isalpha(*p1)&&p1>=xx[i]) p1--; memcpy(t1,p1+1,p2-p1); t1[p2-p1]=0; strcat(t,t1); strcat(t,\if(p1

strcpy(xx[i],t); } }

原程序如下:

# include\# include\# include\

char xx[50][80]; int maxline=0;

int ReadDat(void); void WriteDat(void);

void StrOR(void) { } void main() {clrscr(); if(ReadDat())

{printf(\return;} StrOR(); WriteDat();

system(\}

int ReadDat(void)

{FILE *fp;int i=0;char *p;

if((fp=fopen(\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(\for(i=0;i

fclose(fp); }

4:函数ReadDat( )实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx中; 请编制函数StrOL( ), 其函数的功能是: 以行为单位对行中以空格或标点符号为分隔的所有单词进行倒排,同时去除标点符号,之后把已处理的字符串(应不含标点符号)仍按行重新存入字符串数组xx中。最后main()函数调用函数WriteDat()把结果xx输出到文件OUT6.DAT中。 例如: 原文: You He Me I am a student. 结果: Me He You student a am I

原始数据文件存放的格式是: 每行的宽度均小于80个字符, 含标点符号和空格。

------------类型:字符串(单词)的倒置和删除。 void StrOL(void) /*标准答案*/ {int I,j,k,strl,l;char c; for(I=0;I

for(j=0;j

if ((c>='A'&&c<='Z')||(c>='a'&&c<='z')||c==' ') ; else xx[I][j]=' '; } for(l=0;l

{char ch[80]={0}; char pp[80]={0}; strl=strlen(xx[l]);

二级C语言 第 3 页 共 68 页

I=strl-1; k=1; while(1) {while

(((xx[l][I]>='a'&&xx[l][I]<='z')||(xx[l][I]>='A'&system(\}

int ReadDat(void)

&xx[l][I]<='z'))&&I>=0) {for(j=k;j>=0;j--)

pp[j+1]=pp[j]; pp[0]=xx[l][I]; k++;I--; } strcat(ch,pp);strcpy(pp, \if(I==-1)break;

while((xx[l][I]<'A'||xx[l][I]>'z')&&I>=0) {for(j=k;j>=0;j--)

pp[j+1]=pp[j]; pp[0]=xx[l][I]; k++; I--;} strcat(ch,pp); strcpy(pp,\k=0;

if(I==-1)break;} strcpy(xx[l],ch); }}

或者:

void StrOL(void) { int i,j,k,m,n,ll; char yy[80];

for(i=0; i < maxline; i++) { ll=strlen(xx[i]); k=n=0; for(j=ll-1; j>=0; j--)

{ if(isalpha(xx[i][j])) k++; else

{ for(m=1; m<=k; m++)

yy[n++]=xx[i][j+m]; k=0; }

if(xx[i][j]==' ') yy[n++]=' '; }

for(m=1; m<=k; m++) yy[n++]=xx[i][j+m]; yy[n]=0; strcpy(xx[i],yy); } }

原程序如下:

# include\# include\# include\# include\char xx[50][80]; int maxline=0;

int ReadDat(void); void WriteDat(void);

void StrOR(void) { }

void main() {clrscr(); if(ReadDat())

{printf(\return;} StrOR(); WriteDat(); 二级C语言{FILE *fp;int i=0;char *p;

if((fp=fopen(\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(\for(i=0;i

fclose(fp); }

5:在文件in.dat中有200个正整数,且每个数均在1000至9999之间。函数ReadDat()读取这200个数存放到数组aa中。请编制函数jsSort(),其函数的功能是:要求按每个数的后三位的大小进行升序排列,然后取出满足此条件的前10个数依次存入数组b中,如果后三位的数值相等,则按原先的数值进行降序排列。最后调用函数WriteDat()把结果bb输出到文件out.dat中。 例:处理前 6012 5099 9012 7025 8088 处理后 9012 6012 7025 8088 5099 注意:部分源程序已给出。

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

void jsSort() /*标准答案*/ {int I,j,data;

for(I=0;I<199;I++) for(j=I+1;j<200;j++)

{if (aa[I]00>aa[j]00)

{data=aa[I];aa[I]=aa[j];aa[j]=data;} else if(aa[I]00==aa[j]00) if(aa[I]

{data=aa[I];aa[I]=aa[j];aa[j]=data;} }

for(I=0;I<10;I++) bb[I]=aa[I]; }

原程序如下:

#include #include #include

第 4 页 共 68 页

int aa[200],bb[10];

void jsSort() { }

void main() {readDat(); jsSort(); writeDat();

system(\}

readDat() {FILE *in; int i;

in=fopen(\

for(i=0; i<200; i++) fscanf(in,\

fclose(in); }

writeDat() {FILE *out; int i; clrscr();

out=fopen(\for(i=0; i<10; i++){

printf(\fprintf(out,\}

fclose(out); }

6:在文件in.dat中有200个正整数,且每个数均在1000至9999之间。函数ReadDat()读取这200个数存放到数组aa中。请编制函数jsSort(),其函数的功能是:要求按每个数的后三位的大小进行降序排列,然后取出满足此条件的前10个数依次存入数组b中,如果后三位的数值相等,则按原先的数值进行升序排列。最后调用函数WriteDat()把结果bb输出到文件out.dat中。 例:处理前 9012 5099 6012 7025 8088 处理后 5099 8088 7025 6012 9012 注意:部分源程序已给出。

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

void jsSort() /*标准答案*/ {int I,j,data;

for(I=0;I<199;I++) for(j=I+1;j<200;j++)

{if (aa[I]00

{data=aa[I];aa[I]=aa[j];aa[j]=data;} else if(aa[I]00==aa[j]00) if(aa[I]>aa[j])

{data=aa[I];aa[I]=aa[j];aa[j]=data;} } for(I=0;I<10;I++) bb[I]=aa[I]; }

原程序如下:

#include #include #include

int aa[200],bb[10];

void jsSort() { }

void main() {

readDat(); jsSort(); writeDat();

system(\}

readDat() {

FILE *in; int i;

in=fopen(\

for(i=0; i<200; i++) fscanf(in,\

fclose(in); }

writeDat() {

FILE *out; int i; clrscr();

out=fopen(\for(i=0; i<10; i++){

printf(\fprintf(out,\}

fclose(out); }

7:已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)四部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT10.DAT中。

注意: 部分源程序存放在PROG1.C中。

请勿改动主函数main( )、读数据函数ReadDat()和输出

二级C语言 第 5 页 共 68 页