為大家收集整理了《2013年計(jì)算機(jī)等考三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題及答案(5)》供大家參考,希望對(duì)大家有所幫助?。?!
函數(shù)ReadDat( )的功能是實(shí)現(xiàn)從文件IN65.DAT中讀取一篇英文文章存入到字符串?dāng)?shù)組xx中。請(qǐng)編制函數(shù)ChA( ),該函數(shù)的功能是:以行為單位把字符串的第一個(gè)字符的ASCII值加第二個(gè)字符的ASCII值,得到第一個(gè)新的字符,第二個(gè)字符的ASCII值加第三個(gè)字符的ASCII值,得到第二個(gè)新的字符,以此類推一直處理到倒數(shù)第二個(gè)字符,最后一個(gè)字符的ASCII值加第一個(gè)字符的ASCII值,得到最后一個(gè)新的字符,得到的新字符分別存放在原字符串對(duì)應(yīng)的位置上。最后把已處理的字符串逆轉(zhuǎn)后仍按行重新存入字符串?dāng)?shù)組xx中,并調(diào)用函數(shù)WriteDat( )把結(jié)果xx輸出到文件OUT65.DAT中。
注意:部分源程序已給出。
原始文件存放的格式是:每行的寬度小于80個(gè)字符,含標(biāo)點(diǎn)符號(hào)和空格。
請(qǐng)勿改動(dòng)主函數(shù)main( )、讀函數(shù)ReadDat( )和寫函數(shù)WriteDat( )的內(nèi)容。
試題程序:
#include
#include
#include
char xx[50][80];
int maxline=0;
int ReadDat();
void WriteDat();
void ChA(void)
{
}
void main()
{
system("CLS");
if(ReadDat())
{
printf("數(shù)據(jù)文件IN65.DAT不能打開(kāi)!\n\007");
return;
}
ChA( );
WriteDat();
}
int ReadDat(void)
{
FILE *fp;
int i=0;
char *p;
if((fp=fopen("IN65.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()
{
FILE *fp;
int i;
system("CLS");
fp=fopen("OUT65.DAT","w");
for(i=0;i
{
printf("%s\n",xx[i]);
fprintf(fp,"%s\n",xx[i]);
}
fclose(fp);
}
【答案】
void ChA(void)
{
int i,j,k; /*定義循環(huán)控制變量*/
int str; /*存儲(chǔ)字符串的長(zhǎng)度*/
char ch,temp; /*定義字符暫存變量*/
for(i=0;i
{
str=strlen(xx[i]); /*求得當(dāng)前行的字符串長(zhǎng)度*/
ch=xx[i][0]; /*將第一個(gè)字符暫存入ch*/
for(j=0;j
/*將該字符的ASCII值與下一個(gè)字符的ASCII值相加,得到新的字符*/
xx[i][j]+=xx[i][j+1];
xx[i][str-1]+=ch;
/*將最后一個(gè)字符的ASCII值與第一個(gè)字符的ASCII值相加,得到最后一個(gè)新的字符*/
for(j=0,k=str-1;j
組xx中*/
{
temp=xx[i][j];
xx[i][j]=xx[i][k];
xx[i][k]=temp;
}
}
}
【解析】本題要對(duì)二維數(shù)組中的字符元素按行處理,首先要求得當(dāng)前行所包含的字符數(shù),并保存第一個(gè)字符。接著通過(guò)循環(huán)逐個(gè)將每個(gè)字符的ASCII值與下一個(gè)字符的ASCII值相加,得到新的字符,存入當(dāng)前位置。然后將保存的第一個(gè)字符與最后一個(gè)字符相加作為新的最后一個(gè)字符。最后再把已經(jīng)處理過(guò)的字符串逆序重新存放到數(shù)組xx中。
函數(shù)ReadDat( )的功能是實(shí)現(xiàn)從文件IN65.DAT中讀取一篇英文文章存入到字符串?dāng)?shù)組xx中。請(qǐng)編制函數(shù)ChA( ),該函數(shù)的功能是:以行為單位把字符串的第一個(gè)字符的ASCII值加第二個(gè)字符的ASCII值,得到第一個(gè)新的字符,第二個(gè)字符的ASCII值加第三個(gè)字符的ASCII值,得到第二個(gè)新的字符,以此類推一直處理到倒數(shù)第二個(gè)字符,最后一個(gè)字符的ASCII值加第一個(gè)字符的ASCII值,得到最后一個(gè)新的字符,得到的新字符分別存放在原字符串對(duì)應(yīng)的位置上。最后把已處理的字符串逆轉(zhuǎn)后仍按行重新存入字符串?dāng)?shù)組xx中,并調(diào)用函數(shù)WriteDat( )把結(jié)果xx輸出到文件OUT65.DAT中。
注意:部分源程序已給出。
原始文件存放的格式是:每行的寬度小于80個(gè)字符,含標(biāo)點(diǎn)符號(hào)和空格。
請(qǐng)勿改動(dòng)主函數(shù)main( )、讀函數(shù)ReadDat( )和寫函數(shù)WriteDat( )的內(nèi)容。
試題程序:
#include
#include
#include
char xx[50][80];
int maxline=0;
int ReadDat();
void WriteDat();
void ChA(void)
{
}
void main()
{
system("CLS");
if(ReadDat())
{
printf("數(shù)據(jù)文件IN65.DAT不能打開(kāi)!\n\007");
return;
}
ChA( );
WriteDat();
}
int ReadDat(void)
{
FILE *fp;
int i=0;
char *p;
if((fp=fopen("IN65.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()
{
FILE *fp;
int i;
system("CLS");
fp=fopen("OUT65.DAT","w");
for(i=0;i
{
printf("%s\n",xx[i]);
fprintf(fp,"%s\n",xx[i]);
}
fclose(fp);
}
【答案】
void ChA(void)
{
int i,j,k; /*定義循環(huán)控制變量*/
int str; /*存儲(chǔ)字符串的長(zhǎng)度*/
char ch,temp; /*定義字符暫存變量*/
for(i=0;i
{
str=strlen(xx[i]); /*求得當(dāng)前行的字符串長(zhǎng)度*/
ch=xx[i][0]; /*將第一個(gè)字符暫存入ch*/
for(j=0;j
/*將該字符的ASCII值與下一個(gè)字符的ASCII值相加,得到新的字符*/
xx[i][j]+=xx[i][j+1];
xx[i][str-1]+=ch;
/*將最后一個(gè)字符的ASCII值與第一個(gè)字符的ASCII值相加,得到最后一個(gè)新的字符*/
for(j=0,k=str-1;j
組xx中*/
{
temp=xx[i][j];
xx[i][j]=xx[i][k];
xx[i][k]=temp;
}
}
}
【解析】本題要對(duì)二維數(shù)組中的字符元素按行處理,首先要求得當(dāng)前行所包含的字符數(shù),并保存第一個(gè)字符。接著通過(guò)循環(huán)逐個(gè)將每個(gè)字符的ASCII值與下一個(gè)字符的ASCII值相加,得到新的字符,存入當(dāng)前位置。然后將保存的第一個(gè)字符與最后一個(gè)字符相加作為新的最后一個(gè)字符。最后再把已經(jīng)處理過(guò)的字符串逆序重新存放到數(shù)組xx中。