2016年3月三级网络技术上机题及答案

  1.函数ReadDat( )的功能是实现从文件中读取一篇英文文章存入到字符串数组xx中。请编制函数SortCharA( ),该函数的功能是:以行为单位对字符按从小到大的顺序进行排序,排序后的结果仍按行重新存入字符串数组xx中。最后调用函数WriteDat( )把结果xx输出到文件中。

2016年3月三级网络技术上机题及答案

例如,原文:dAe,BfC

CCbbAA

结果:ABCdef

AACCbb

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

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

请勿改动主函数main( )、读函数ReadDat( )和写函数WriteDat( )的内容。

试题程序:

#include

#include

#include

char xx[50][80];

int maxline=0;

int ReadDat(void);

void WriteDat(void);

void SortCharA()

{

}

void main()

{

system("CLS");

if (ReadDat())

{

printf("数据文件不能打开!n07");

return;

}

SortCharA();

WriteDat();

}

int ReadDat(void)

{

FILE *fp;

int i=0;

char *p;

if((fp=fopen("","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()

{

FILE *fp;

int i;

system("CLS");

fp=fopen("","w");

for(i=0;i

{

printf("%sn",xx[i]);

fprintf(fp,"%sn",xx[i]);

}

fclose(fp);

}

【答案】

void SortCharA()

{

int i,j,k; /*定义循环控制变量*/

int str; /*存储字符串的长度*/

char temp; /*数据交换时的暂存变量*/

for (i=0;i

{

str=strlen(xx[i]); /*求得当前行的'字符串长度*/

for(j=0;j

for(k=j+1;k<>

if (xx[i][j]>xx[i][k])

{

temp=xx[i][j];

xx[i][j]=xx[i][k];

xx[i][k]=temp;

}

}

}

【解析】本题主要考查数组的访问及排序问题。

通过双重循环结构逐行获取字符进行处理,首先使用字符串处理函数strlen()来求出每一行的字符串长度。然后运用选择法逐行对字符按照从小到大的顺序进行排序。

  2.编写一个函数findStr( ),该函数统计一个长度为2的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为"asd asasdfg asd as zx67 asd mklo",子字符串为"as",函数返回值是6。

  函数ReadWrite( )的功能是实现从文件中读取两个字符串,并调用函数findStr(),最后把结果输出到文件中。

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

请勿改动主函数main() 和其他函数中的任何内容,仅在函数 findStr()的花括号中填入你所编写的若干语句。

试题程序:

#include

#include

#include

void ReadWrite();

int findStr(char *str,char *substr)

{

}

void main()

{

char str[81],substr[3];

int n;

system("CLS");

printf("输入原字符串:");

gets(str);

printf("输入子字符串:");

gets(substr);

puts(str);

puts(substr);

n=findStr(str,substr);

printf("n=%dn",n);

ReadWrite();

}

void ReadWrite()

{

char ch,str[81],substr[3];

int n,len,i=0;

FILE *rf,*wf;

rf=fopen("","r");

wf=fopen("","w");

while(i<>

{

fgets(str,80,rf);

fgets(substr,10,rf);

len=strlen(substr)-1;

ch=substr[len];

if(ch=='n'||ch==0x1a)

substr[len]=0;

n=findStr(str,substr);

fprintf(wf,"%dn",n);

i++;

}

fclose(rf);

fclose(wf);

}【答案】

int findStr(char *str,char *substr)

{

int n=0; /*定义计数器变量,统计出现次数*/

char *p,*r; /*定义指针变量来分别指向两个字符串*/

while(*str) /*如果字符串没有结束,则一直循环下去*/

{

p=str; /*指针p指向字符串首地址*/

r=substr; /*指针r指向子字符串首地址*/

while(*r) /*若子字符串没有结束,则循环继续*/

if(*r==*p)

/*如果子字符串的第一个字符等于字符串中的该字符,则继续比较下一个字符*/

{

r++;

p++;

}

else

break; /*否则退出循环*/

if(*r=='') /*如果子字符串在字符串中出现了一次*/

n++; /*则n加1,进行统计*/

str++; /*指向字符串中的下一个字符*/

}

return n; /*返回统计结果n*/

}

【解析】本题主要考查了指针的相关操作。

首先,通过外层的while循环取字符串的每一个字符,取完字符串的所有字符之后,循环才会终止。用两个字符型指针分别指向两个字符串。逐个将字符串的字符跟子字符串的字符对比,如果相等,则两个指针都自加1,分别指向两个串的下一个字符。若不相等,则主串的指针加1,子串的指针重新指向起始位置,继续比较下一个字符。