- 相關(guān)推薦
計算機等級考試三級網(wǎng)絡(luò)技術(shù)上機題及答案
2016下半年計算機等級考試備考中,為方便考生復(fù)習(xí)好計算機三級網(wǎng)絡(luò)技術(shù),yjbys小編特整理最新網(wǎng)絡(luò)技術(shù)模擬試題及答案解析如下:
1.編寫一個函數(shù)findStr( ),該函數(shù)統(tǒng)計一個長度為2的字符串在另一個字符串中出現(xiàn)的次數(shù)。例如,假定輸入的字符串為"asd asasdfg asd as zx67 asd mklo",子字符串為"as",函數(shù)返回值是6。
函數(shù)ReadWrite( )的功能是實現(xiàn)從文件in68.dat中讀取兩個字符串,并調(diào)用函數(shù)findStr(),最后把結(jié)果輸出到文件out68.dat中。
注意:部分源程序已給出。
請勿改動主函數(shù)main() 和其他函數(shù)中的任何內(nèi)容,僅在函數(shù) 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=%d\n",n);
ReadWrite();
}
void ReadWrite()
{
char ch,str[81],substr[3];
int n,len,i=0;
FILE *rf,*wf;
rf=fopen("in68.dat","r");
wf=fopen("out68.dat","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,"%d\n",n);
i++;
}
fclose(rf);
fclose(wf);
}【答案】
int findStr(char *str,char *substr)
{
int n=0; /*定義計數(shù)器變量,統(tǒng)計出現(xiàn)次數(shù)*/
char *p,*r; /*定義指針變量來分別指向兩個字符串*/
while(*str) /*如果字符串沒有結(jié)束,則一直循環(huán)下去*/
{
p=str; /*指針p指向字符串首地址*/
r=substr; /*指針r指向子字符串首地址*/
while(*r) /*若子字符串沒有結(jié)束,則循環(huán)繼續(xù)*/
if(*r==*p)
/*如果子字符串的第一個字符等于字符串中的該字符,則繼續(xù)比較下一個字符*/
{
r++;
p++;
}
else
break; /*否則退出循環(huán)*/
if(*r=='\0') /*如果子字符串在字符串中出現(xiàn)了一次*/
n++; /*則n加1,進行統(tǒng)計*/
str++; /*指向字符串中的下一個字符*/
}
return n; /*返回統(tǒng)計結(jié)果n*/
}
【解析】本題主要考查了指針的相關(guān)操作。
首先,通過外層的while循環(huán)取字符串的每一個字符,取完字符串的所有字符之后,循環(huán)才會終止。用兩個字符型指針分別指向兩個字符串。逐個將字符串的字符跟子字符串的字符對比,如果相等,則兩個指針都自加1,分別指向兩個串的下一個字符。若不相等,則主串的指針加1,子串的指針重新指向起始位置,繼續(xù)比較下一個字符。
2.函數(shù)ReadDat()的功能是實現(xiàn)從文件IN67.DAT中讀取一篇英文文章存入到字符串?dāng)?shù)組xx中;請編制函數(shù)StrOL(),該函數(shù)的功能是:以行為單位對行中以空格或標(biāo)點符號為分隔的所有單詞進行倒排。最后把已處理的字符串(應(yīng)不含標(biāo)點符號)仍按行重新存入字符串?dāng)?shù)組xx中,最后調(diào)用函數(shù) WriteDat()把結(jié)果xx輸出到文件OUT67.DAT中。
例如,原文:You He Me
I am a student.
結(jié)果:Me He You
student a am I
原始數(shù)據(jù)文件存放的格式是:每行的寬度均小于80個字符,含標(biāo)點符號和空格。
注意:部分源程序已給出。
請勿改動主函數(shù)main()、讀函數(shù)ReadDat()和寫函數(shù)WriteDat()的內(nèi)容。
試題程序:
#include
#include
#include
#include
#include
char xx[50][80];
int maxline = 0;/* 文章的總行數(shù) */
int ReadDat(void);
void WriteDat(void);
void StrOL(void)
{
}
void main()
{
system("CLS");
if (ReadDat ())
{
printf("數(shù)據(jù)文件 IN67.DAT不能打開!\n\007");
return;
}
StrOL();
WriteDat();
}
int ReadDat(void)
{
FILE *fp;
int i = 0;
char *p;
if((fp = fopen("IN67.DAT", "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("OUT67.DAT", "w");
for(i = 0; i < maxline;="" i++)="">
{
printf("%s\n", xx[i]);
fprintf(fp, "%s\n", xx[i]);
}
fclose(fp);
}
【答案】
void StrOL(void)
{
int i,j,k; /*定義數(shù)組下標(biāo)變量*/
char t[80],t1[80]; /*定義數(shù)組暫存取得的單詞*/
for(i=0;i
{
j=k=strlen(xx[i])-1; /*將每行末尾字符的下標(biāo)保存在j和k中*/
t[0]=t1[0]='\0'; /*初始化兩個字符數(shù)組*/
while(1) /*無條件循環(huán),循環(huán)體內(nèi)有結(jié)束循環(huán)的語句*/
{
while(isalpha(xx[i][j])==0&&j>=0)
/*若以j為下標(biāo)的字符不是字母并且還在數(shù)組xx之內(nèi)*/
k=--j;
while(isalpha(xx[i][j])&&j>=0)
/*若以j為下標(biāo)的字符是字母并且還在數(shù)組xx之內(nèi)*/
j--;
/*當(dāng)退出這個循環(huán)時,xx[i][j+1]和xx[i][k]分別是同一個單詞的第一個和最后一個字母*/
memcpy(t1,&xx[i][j+1],k-j); /*將該單詞保存到字符數(shù)組t1*/
t1[k-j]='\0'; /*為t1中的單詞添加字符串結(jié)束標(biāo)志*/
strcat(t,t1); /*將單詞保存到數(shù)組t中*/
strcat(t," "); /*單詞之間用空格分隔*/
if(j<0)>
break; /*則退出外層while循環(huán)*/
}
strcpy(xx[i],t); /*按行將處理完了字符串重新保存到數(shù)組xx中*/
}
}
【解析】本題的主要算法是先讓兩字符指針都指向每一行字符的串尾,然后使其中一指針(p1)往前移動,當(dāng)出現(xiàn)pl指向的不是字母時則表示在p1+1與 p2之間是一個單詞,將該單詞存入字符數(shù)組t1中,最后將t1連接到新串t中;接著再往前找第二個單詞,依次類推直到p1越過字符串的起始位置。再將處理完的字符串重新儲存到數(shù)組xx中,然后進入下一行的處理過程。