早教吧 育儿知识 作业答案 考试题库 百科 知识分享
早教吧考试题库频道 --> 计算机类考试 -->计算机三级 -->

函数ReadDat()的功能是实现从文件IN32.DAT中读取一篇英文文章存入到字符串数组xx中。请编数StrOR(

题目

函数ReadDat()的功能是实现从文件IN32.DAT中读取一篇英文文章存入到字符串数组xx中。请编数StrOR(),该函数的功能是:以行为单位把字符串中所有小写字母。左边的字符串内容移至该串的右边

存放,然后把小写字母。删除,余下的字符串内容移到已处理字符串的左边存放,最后把已处理的字符串仍按行重新存入字符串数组xx中。最后调用函数WriteDat()把结果输出到文件OUT32.DAT中。

例如, 原文: You can create an index on any field

you have the correct record

结果: n any field Yu can create an index

rd yu have the crrect rec

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

注意:部分源程式序已给出

请勿改动主函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)

{

}

void main ()

{

clrscr ( );

if (ReadDat ())

{

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

return;

}

StrOR ();

WriteDat ();

}

int ReadDat (void)

{

FILE *fp;

iht i=0;

char *p;

if ((fp=fopen("IN32.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 (void)

{

FILE *fp;

int i;

clrscr ();

fp=fopen ( "OUT32. DAT", "w" );

for (i=0;i {

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

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

}

fclose (fp);

}

参考答案
正确答案:void StrOR(void) { int I j k index strl; char ch; for (I=O; Imaxline; I++) { Strl=s'trlen (xx [ I ] ); /*求各行的长度*/ index=strl; for (j=O; jstrl; j++) /*将一行中所以小写字母o右边的字符依次 向左移一位并删除字母.*/ if (xx[I] [j]=='o') { for (k=j; k xx[I] [k]=xx[I] [k+l]; xx[I] [strl-1]=' '; index=j; /*记录下最后一个o所在的位置* / } for (j=strl-1; j >=index; j--) /*最后一个o右侧的所有字符都移到已处理字 符串的左边*/ ch=xx[I] [strl-1]; for (k=strl-1; k>O; k--) xx[I] [k]=xx[I] [k-l]; xx[I] [O]=ch; } } }
void StrOR(void) { int I, j, k, index, strl; char ch; for (I=O; Imaxline; I++) { Strl=s'trlen (xx [ I ] ); /*求各行的长度*/ index=strl; for (j=O; jstrl; j++) /*将一行中所以小写字母o右边的字符依次 向左移一位,并删除字母.*/ if (xx[I] [j]=='o') { for (k=j; k xx[I] [k]=xx[I] [k+l]; xx[I] [strl-1]=' '; index=j; /*记录下最后一个o所在的位置* / } for (j=strl-1; j >=index; j--) /*最后一个o右侧的所有字符都移到已处理字 符串的左边*/ ch=xx[I] [strl-1]; for (k=strl-1; k>O; k--) xx[I] [k]=xx[I] [k-l]; xx[I] [O]=ch; } } } 解析:本题考查的知识点如下:
(1)循环结构与选择结构的嵌套使用。
(2)字符数组中的元素的移动。
(3)字符串处理函数的使用。
在本题中,以行作为字符串处理的基本单位。首先,要确定该行字符串的长度。然后使用循环结构依次对字符进行处理。先找到字符o,将o右侧的字符依次向左移。这个操作同时能够删除字符o。记录下最后一个。所在的位置,在这个。右侧的所有字符都要移到已处理字符串的左边,这个过程也是使用循环来完成的。最后,对文章中的每一行都进行这一操作即可。`
看了函数ReadDat()的功能是...的网友还看了以下:

统计数据文件主要可以分为字符文件、记录文件等。 财会类考试 2020-05-21 …

统计数据文件主要可以分为字符文件、记录文件等。( )A.正确B.错误 财会类考试 2020-05-21 …

在文件系统中,文件的逻辑结构可分为两类,它们是______。A.流式文件和记录式文件B.字符文件和二 计算机类考试 2020-05-24 …

在文件系统中,文件的逻辑结构可分为两类,它们是()。A.流式文件和记录式文件B.字符文件和二进制文 计算机类考试 2020-05-24 …

VB要求从某一字符串中删除指定的字符(假设所含的英文字母均为小写字母),并将处理后的字符串重新输出 其他 2020-06-18 …

c语言算法问题在一个木板上刻一个长度为n的只由“E”,“F”,“O”三种字符组成的字符串(可以只有 其他 2020-06-30 …

求个C语言程序设计答案发我邮箱849839606@qq.com回文字符串就是正读和反读都相同的字符串 其他 2020-10-30 …

有一道c++题题是这样的编码原则:(1)如果访问到字符A,W,F就转化成I;(2)如果访问到字符C, 其他 2020-11-07 …

有一种密码,明文是由三个字符组成,密码是由明文对应的五个数字组成,编码规则如下表,明文由表中每一排取 其他 2020-11-07 …

我有一个文本文件想用替换功能在每行的相同位置加入同样的字符文件太多了一个一个弄很费时间00:00\x 其他 2020-11-28 …