手机图片 苏州便民网 诺基亚手机
首页 | 英语四六级 | 日语学习 | 网络学院 | 考研 | 公务员考试 | 计算机 | 笑话 | 减肥 设大学生网为首页 加入收藏
一级真题 二级真题 三级真题 四级真题
 
 
 
 
 

您的位置:首页 >> 计算机 >> 历年真题 >> 三级真题 >> 浏览信息

正文内容

2006年9月全国计算机等级考试三级c语言上机真题汇编

时间:2006-10-10 来源:大学生计算机等级考试 打印本文

题目1(上机题库id 14、id 27(提供isP()函数;上机题库id 23题)请编写一个函数jsValue(int m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m的k个素数存入数组xx传回。最后调用函数writeDat()读取10组数据,分别得出结果且把结果输出到文件out.dat中。部分源程序存在文件prog1.c中。例如:若输入17 5 则应输出:19,23,29,31,37。请勿改动主函数main()和写函数writeDat()的内容。#include <conio.h>#include <stdio.h>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[]){ int s=0;for(m=m+1;k>0;m++)if(isP(m)) { xx[s++]=m; k--;}}main(){int m,n,xx[1000];clrscr();printf("/nPlease enter two integers:");scanf("%d%d",&m,&n);num(m,n,xx);for(m=0;m<n;m++)printf("%d ",xx[m]);printf("/n");readwriteDat();}void readwriteDat(){int m,n,xx[1000], i;FILE *rf,*wf;rf=fopen("in.dat","r");wf=fopen("out.dat","w");for(i=0;i<10;i++){fscanf(rf,"%d %d",&m,&n);num(m,n,xx);for(m=0;m<n;m++)fprintf(wf,"%d ",xx[m]);fprintf(wf,"/n");}fclose(rf);fclose(wf);} 无忧id 14题(无isP()函数)#include <stdio.h>void jsValue(int m,int k,int xx[]){ int i,j,s=0;for(i=m+1;k>0;i++){ for(j=2;j<i;j++)if(i%j==0) break;if(i==j) { xx[s++]=i; k--;}}}main(){int m,n,zz[100];printf("/n请输入两个整数:");scanf("%d%d",&m,&n);jsValue(m,n,zz);for(m=0;m<n;m++)printf("%d ",zz[m]);printf("/n");writeDat();}writeDat(){int m,n,zz[100],i;FILE *in,*out;in=fopen("in.dat","r");out=fopen("out.dat","w");for(i=0;i<10;i++){fscanf(in,"%d%d",&m,&n);jsValue(m,n,zz);for(m=0;m<n;m++)fprintf(out,"%d ",zz[m]);fprintf(out,"/n");}fclose(in);fclose(out);} 另一解法:void num(int m,int k,int xx[]){int n=0,data=m+1;while(n<k){if(isP(data)) xx[n++]=data;data++;}}*****************************************************************************************★题目2(上机题库id 143 整数排序题) 已知数据文件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()的内容。#include <stdio.h>#define MAX 200int a[MAX], b[MAX], cnt = 0 ;void jsVal(){ int i,j,qw,bw,sw,gw;for(i=0;i<MAX;i++){ qw=a[i]/1000; bw=a[i]/100%10; sw=a[i]%100/10; gw=a[i]%10;if(qw&&qw%2==0&&bw%2==0&&sw%2==0&&gw%2==0) b[cnt++]=a[i];}for(i=0;i<cnt-1;i++)for(j=i+1;j<cnt;j++)if(b[i]<b[j]) { qw=b[i]; b[i]=b[j]; b[j]=qw;}}void readDat(){int i ;FILE *fp ;fp = fopen("in.dat", "r") ;for(i = 0 ; i < MAX ; i++) fscanf(fp, "%d", &a[i]) ;fclose(fp) ;}void main(){int i ;readDat() ;jsVal() ;printf("满足条件的数=%d/n", cnt) ;for(i = 0 ; i < cnt ; i++) printf("%d ", b[i]) ;printf("/n") ;writeDat() ;}writeDat(){FILE *fp ;int i ;fp = fopen("out.dat", "w") ;fprintf(fp, "%d/n", cnt) ;for(i = 0 ; i < cnt ; i++) fprintf(fp, "%d/n", b[i]) ;fclose(fp) ;}*****************************************************************************************★☆题目3(上机题库id 133题;上机题库id 59、99字符串位置倒置题)函数ReadDat( )实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx中;请编制函数StrOR( ),其函数的功能是:以行为单位依次把字符串中所有小写字母o左边的字符串内容移到该串的右边存放,然后把小写字母o删除,余下的字符串内容移到已处理字符串的左边存放,之后把已处理的字符串仍按行重新存入字符串数组xx中。最后main()函数调用函数WriteDat()把结果xx输出到文件OUT5.DAT中。例如:原文:n any field.Yu can create an index you have the correct record.结果:n any field. Yu can create an indexrd. yu have the crrect rec原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。注意:部分源程序存放在文件prog1.c中。请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。#include <stdio.h>#include <string.h>#include <conio.h>char xx[50][80] ;int maxline = 0 ; /* 文章的总行数 */int ReadDat(void) ;void WriteDat(void) ;void StrOR(void){int i,righto,j,s,k;char tem[80];for(i=0;i<maxline;i++) /*倒序循环*/for(j=strlen(xx[i])-1;j>=0;j--){ k=0; memset(tem,0,80); /*初始化字符串数组tem*/if(xx[i][j]=='o') /*如果当前字符为'o',进入以下语句*/{righto=j; /*则将此字符中位置j的值赋给righto*/for(s=righto+1;s<strlen(xx[i]);s++) tem[k++]=xx[i][s]; /*从righto的下一跳开始将其后所有的字符都存入到tem中*/for(s=0;s<righto;s++) /*从当前行首部开始到出现字符'o'的位置(righoto)之前开始循环*/if(xx[i][s]!='o') tem[k++]=xx[i][s]; /*将不是字符'o'的字符全存入到tem中*/strcpy(xx[i],tem); /*将当前已处理的字符重新存入当前行xx*/}else continue;}}void main(){clrscr() ;if(ReadDat()) {printf("数据文件IN.DAT不能打开!/n/007") ;return ;}StrOR() ;WriteDat() ;}int ReadDat(void){FILE *fp ;int i = 0 ;char *p ;if((fp = fopen("IN.DAT", "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 ;clrscr() ;fp = fopen("OUT5.DAT", "w") ;for(i = 0 ; i < maxline ; i++) {printf("%s/n", xx[i]) ;fprintf(fp, "%s/n", xx[i]) ;}fclose(fp) ;}解法二:void StrOR(void){ int i;char a[80],*p;for(i=0;i<maxline;i++){ p=strchr(xx[i],'o');while(p){ 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,j; char yy[80],*p;for(i=0; i<maxline;i++)for(j=0; j<strlen(xx[i]); j++)if(xx[i][j]=='o'){ p=&xx[i][j+1];strcpy(yy,p); /*将指针p所指向的字符串拷贝到字符串yy中去*/strncat(yy,xx[i],j); /*将字符串xx[i]中前j个字符连接到yy中*/strcpy(xx[i],yy); /*将字符串yy重新拷贝到字符串xx[i]中去*/j=0; /* 开始下一次的扫描。*/}}相关库函数解释:char *strncat(char *dest, const char *src, size_t maxlen)功能:将字符串src中前maxlen个字符连接到dest中相关头文件:string.hchar *strcpy(char *dest, const char *src)功能:将字符串src拷贝到字符串dest中去相关头文件:string.h*****************************************************************************************★☆题目4(无忧id 24题 上机题库id 9 字符串单词倒置题)函数ReadDat()实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx中,请编制函数StrOL(),其函数的功能是:以行为单位对行中以空格或标点符号为分隔的所有单词进行倒排。最后把已处理的字符串(应不含标点符号)仍按行重新存入字符串数组xx中,最后调用函数writeDat()把结果xx输出到文件OUT6.DAT中。例如:原文:You He MeI am a student.     结果:Me He Youstudent a am I原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。部分源程序存在文件prog1.c中。请勿改动主函数main()、读数据函数ReadDat()和输出数据函数writeDat()的内容。#include <stdio.h>#include <string.h>#include <conio.h>#include <ctype.h>char xx[50][80];int maxline=0;/*文章的总行数*/int ReadDat(void);void WriteDat(void);/*在无忧及上机题库版模拟系统中都通过测试(输入文件句末有标点的在输出文件中句前有空格*/void StrOL(void) { int i,j,k,s,m,strl;char str[80];for(i=0;i<maxline;i++){ strl=strlen(xx[i]);memset(str,0,80); /*初始化这字符串数组str*/s=k=0;for(j=strl-1;j>=0;j--) /*从当前字符串尾部开始向前倒序循环,实现题意要求的倒排*/{ if(isalpha(xx[i][j])) k++; /*如果当前字符是字母a~z或A~Z,则k加一*/else { for(m=1;m<=k;m++) /*否则将长度为k的单词顺序存入到字符串数组str中,s值加1*/str[s++]=xx[i][j+m];k=0; /*将k值清0,以方便下一个单词的长度计数*/}if(!isalpha(xx[i][j])) str[s++]=' '; /*如果当前字符不是字母a~z或A~Z,则以空格代之存入到字符串数组str中,s值加一*/}for(m=1;m<=k;m++) /*此时的k值为当前字符串中第一个单词的长度,但在上一个for循环中没能存入到字符串数组str中,所以在这里将其存入到str中*/str[s++]=xx[i][j+m];str[s]='/0'; /*在当前行尾加0以标记此行的结束*/strcpy(xx[i],str); /*将倒排好的当前字符串重新存回到当前行xx中*/}}void main(){clrscr();if(ReadDat()){printf("数据文件IN.DAT不能打开!/n/007");return;}StrOL();WriteDat();}int ReadDat(void){FILE *fp;int i=0;char *p;if((fp=fopen("IN.DAT","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;clrscr();fp=fopen("OUT6.DAT","w");for(i=0;i<maxline;i++){printf("%s/n",xx[i]);fprintf(fp,"%s/n",xx[i]);}fclose(fp);}上机题库版模拟系统中的解法/*在无忧模拟系统中没通过测试(输入文件句末有标点的在输出文件中句前无空格*/void StrOL(void) {int i, j ;char word[21], yy[80], zz[80], *p ;for(i = 0 ; i < maxline ; i++) {p = xx[i] ;j = 0 ;memset(word, 0, 21) ;memset(yy, 0, 80) ;while(*p) {if(isalpha(*p)) {word[j++] = *p++ ;if(*p) continue ;}strcpy(zz, yy) ;sprintf(yy, "%s %s", word, zz) ;j = 0 ;memset(word, 0, 21) ;while(*p && (!isalpha(*p))) p++ ;}strcpy(xx[i], yy) ;}}另一解法(): /*在无忧及上机题库版模拟系统中都通过测试(输入文件句末有标点的在输出文件中句前有空格*/void StrOL(void){ int i,j,m;char str[80];for(i=0;i<maxline;i++){ m=strlen(xx[i]);memset(str,0,80); for(j=m-1;j>=0;j--)if(!isalpha(xx[i][j])){ strcat(str,xx[i]+j+1);strcat(str," ");xx[i][j]='/0';}strcat(str,xx[i]); strcpy(xx[i],str);}}实际上机考试时上面几种解法都可以采用。*****************************************************************************************
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 下一页

上一篇:下面没有链接了
下一篇:2006年9月全国计算机等级考试三级pc笔试试卷及答案

相关阅读:

·2006年12月24日大学英语新六级考试考试大纲  (2006-10-26)
·2006年12月英语新六级考试试点180所院校名单  (2006-10-26)
·2006年12月英语四六级考试临近 "枪手"频频出现  (2006-10-26)
·2006年12月23日大学英语四级考试最新预测卷(一)  (2006-10-26)
·2006年12月23日新英语四级考试完全解密  (2006-10-23)
·2006年6月17日大学英语六级考试听力原文  (2006-10-20)
·2006年6月17日大学英语六级考试听力题目录音  (2006-10-20)
·2006年6月17日大学英语四级考试听力题录音  (2006-10-20)

网站简介 | 广告服务 | 联系方式 | 意见建议 | 网站地图 | 版权声明 | 友情连接

大学生网 Stuun.com 版权所有