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
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, \ 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;} } 原程序如下: #include 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, \ 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, \ 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 for(j=0;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 {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';