计算机等级考试三级网络技术上机题及答案

来源:文书网 1.12W

2016下半年计算机等级考试备考中,为方便考生复习计算机三级网络技术,yjbys小编特整理最新网络技术模拟试题及答案解析如下:

计算机等级考试三级网络技术上机题及答案

1.编写一个函数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,子串的'指针重新指向起始位置,继续比较下一个字符。

2.函数ReadDat()的功能是实现从文件中读取一篇英文文章存入到字符串数组xx中;请编制函数StrOL(),该函数的功能是:以行为单位对行中以空格或标点符号为分隔的所有单词进行倒排。最后把已处理的字符串(应不含标点符号)仍按行重新存入字符串数组xx中,最后调用函数 WriteDat()把结果xx输出到文件中。

例如,原文:You He Me

I am a student.

结果:Me He You

student a am I

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

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

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

试题程序:

#include

#include

#include

#include

#include

char xx[50][80];

int maxline = 0;/* 文章的总行数 */

int ReadDat(void);

void WriteDat(void);

void StrOL(void)

{

}

void main()

{

system("CLS");

if (ReadDat ())

{

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

return;

}

StrOL();

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(void)

{

FILE*fp;

int i;

system("CLS");

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

for(i = 0; i < maxline;="" i++)="">

{

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

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

}

fclose(fp);

}

【答案】

void StrOL(void)

{

int i,j,k; /*定义数组下标变量*/

char t[80],t1[80]; /*定义数组暂存取得的单词*/

for(i=0;i

{

j=k=strlen(xx[i])-1; /*将每行末尾字符的下标保存在j和k中*/

t[0]=t1[0]=''; /*初始化两个字符数组*/

while(1) /*无条件循环,循环体内有结束循环的语句*/

{

while(isalpha(xx[i][j])==0&&j>=0)

/*若以j为下标的字符不是字母并且还在数组xx之内*/

k=--j;

while(isalpha(xx[i][j])&&j>=0)

/*若以j为下标的字符是字母并且还在数组xx之内*/

j--;

/*当退出这个循环时,xx[i][j+1]和xx[i][k]分别是同一个单词的第一个和最后一个字母*/

memcpy(t1,&xx[i][j+1],k-j); /*将该单词保存到字符数组t1*/

t1[k-j]=''; /*为t1中的单词添加字符串结束标志*/

strcat(t,t1); /*将单词保存到数组t中*/

strcat(t," "); /*单词之间用空格分隔*/

if(j<0)>

break; /*则退出外层while循环*/

}

strcpy(xx[i],t); /*按行将处理完了字符串重新保存到数组xx中*/

}

}

【解析】本题的主要算法是先让两字符指针都指向每一行字符的串尾,然后使其中一指针(p1)往前移动,当出现pl指向的不是字母时则表示在p1+1与 p2之间是一个单词,将该单词存入字符数组t1中,最后将t1连接到新串t中;接着再往前找第二个单词,依次类推直到p1越过字符串的起始位置。再将处理完的字符串重新储存到数组xx中,然后进入下一行的处理过程。

热门标签