三级数据库技术机试-298.pdfVIP

  • 0
  • 0
  • 约2千字
  • 约 2页
  • 2021-11-13 发布于江西
  • 举报
三级数据库技术机试-298 (总分:100.00,做题时间:90 分钟) 一、上机题 (总题数:1,分数:100.00) 1.函数ReadDat()的功能是实现从文件IN39.DAT 中读取一篇英文文章存入到字符串数组xx 中。请编制函 数ChA㈠,该函数的功能是:以行为单位把字符串的第一个字符的ASCII 值加第二个字符的ASCII 值,得 到第一个新的字符,第二个字符的ASCII 值加第三个字符的ASCII 值,得到第二个新的字符,以此类推一 直处理到倒数第二个字符,最后一个字符的ASCII 值加第一个字符的ASCII 值,得到最后一个新的字符, 得到的新字符分别存放在原字符串对应的位置上。最后把已处理的字符串逆转后仍按行重新存入字符串数 组肛中,并调用函数WriteDat()把结果xx 输出到文件OUT39.DAT 中。 注意:部分源程序已给出。 原始文件存放的格式是:每行的宽度小于80 个字符,含标点符号和空格。 请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。 试题程序: #include<stdio.h> #include<string.h> #incIude<conio.h> char xx[50] [80]; int maxline=0; int ReadDat(); void writeDat(); void ChA(void) void main () clrscr ( ); if (ReadDat ( ) ) printf (数据文件IN39 .DAT 不能打开!/n/007); return; ChA ); WriteDat ( ); int ReadDat (void) FILE *fp; int i=0; char *p; if ( (fp= fopen ( IN39. DAT, r ) ) ==NULL ) return 1; while (fgets (xx [i] , 80, fp)! =NULL) p=strchr(xx[i], In); if(p) *p=0; i++; maxline=i; fclose (fp); return 0; void WriteDat ( ) FILE *fp; int i; clrscr ( ); fp=fopen (OUT39.DAT, w); for (i=0; i<maxline; i++) printf ( %s/n ,xx[i] ); fprintf(fp,%s/n,xx[i]); fclose (fp); (分数:100.00) __________________________________________________________________________________________ 正确答案:(void ChA(void) { int i,j, k,str; char ch; for(i=0;i<maxline;i++) { str=strlen (xx[i]); /*求各行字符串的总长度*/ ch=xx[i][0]; for(j=0;j<str-1;j++) /*将该字符的ASCII 值与下一个字符的ASCII 值相加,得到新的字符*/ xx[i][j]+=xx[i][j+1]; xx[i][str-1]+=ch;/*将最后一个字符的ASCII 值与第一个字符的ASCII 值相加,得到最后一个新的字符 */ for(j=0,k=str-1; j<str/2;j++,k--) /*将字符串逆转后仍按行重新存入字符串数组xx 中*/ { ch=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=ch; } } }) 解析:[解析] 本题考查的知识点如下: (1)字符变量的整数运算。 (2)字符的逆序排列。 因为是以行为处理单位,所以要先求得每一行中字符的个数。在C 语言中,字符型数据可参与任何整数运 算,实际参与运算的是字符的ASCII 码。这里可以直接将字符的ASCII 码相加,即可得到所要结果。使用 循环结构依次对字符进行处理,最后一个字符要单独处理。逆序排列采用的方法是:从两边向中间移动。 数组中第一个字符与最后,个字符交换,第二个与倒数第二个交换,按照此规律直到中间一个或两个字符 (数组中字符个数为奇数时,最后中间只有一个字符,否则有两个字符)。

文档评论(0)

1亿VIP精品文档

相关文档