計算機三級網(wǎng)絡技術(shù)上機題庫及答案
網(wǎng)絡技術(shù)考核計算機網(wǎng)絡基礎知識及計算機網(wǎng)絡應用系統(tǒng)開發(fā)和管理的基本技能。以下是小編幫大家整理的計算機三級網(wǎng)絡技術(shù)上機題庫及答案,僅供參考,歡迎大家閱讀。
(資料圖片)
函數(shù)ReadDat()的功能是實現(xiàn)從文件ENG51.IN中讀取一篇英文文章,存入到字符串數(shù)組xx中;請編制函數(shù)encryptChar(),按給定的替代關(guān)系對數(shù)組xx中的所有字符進行替代,結(jié)果仍存入數(shù)組xx的對應的位置上,最后調(diào)用函數(shù)WriteDat()把結(jié)果xx輸出到文件PS51.DAT中。
替代關(guān)系:f(p)=p*11 mod 256(p是數(shù)組xx中某一個字符的ASCII值,f(p)是計算后新字符的`ASCII值),如果計算后f(p)的值小于等于32或f(p)對應的字符是數(shù)字0至9,則該字符不變,否則將f(p)所對應的字符進行替代。
注意:部分源程序已給出。
原始數(shù)據(jù)文件存放的格式是:每行的寬度均小于80個字符。
請勿改動主函數(shù)main()、讀函數(shù)ReadDat()和寫函數(shù)WriteDat()的內(nèi)容。
試題程序:
#include
#include
#include
#include
unsigned char xx[50][80];
int maxline = 0; /* 文章的總行數(shù) */
int ReadDat(void);
void WriteDat(void);
void encryptChar()
{
}
void main()
{
system("CLS");
if(ReadDat())
{
printf("數(shù)據(jù)文件ENG51.IN不能打開! 07");
return;
}
encryptChar();
WriteDat();
}
int ReadDat(void)
{
FILE *fp;
int i=0;
unsigned char *p;
if((fp = fopen("ENG51.IN", "r")) ==NULL)
return 1;
while(fgets(xx[i], 80, fp) !=NULL)
{
p = strchr(xx[i], " ");
if(p) *p = 0;
i++;
}
maxline = i;
fclose(fp);
return 0;
}
void WriteDat(void)
{
FILE *fp;
int i;
fp = fopen("PS51.DAT", "w");
for(i = 0; i < maxline; i++)
{
printf("%s ", xx[i]);
fprintf(fp, "%s ", xx[i]);
}
fclose(fp);
}
【參考答案及解析】
void encryptChar()
{
int i,j; /*定義循環(huán)控制變量*/
int str; /*存儲字符串的長度*/
char ch; /*存儲當前取得的字符*/
for(i=0;i {
str=strlen(xx[i]); /*求得當前行的字符串長度*/
for(j=0;j {
ch=xx[i][j] *11%6;
if(ch<=32 ch="">="0" && ch<="9") )
continue; /*如果計算后的值小于等于32或f(p)對應的字符是數(shù)字0至9,則該字符不變*/
else
xx[i][j]=ch; /*否則按給定的替代關(guān)系進行替代*/
}
}
}
【解析】本題要求對二維數(shù)組中的字符元素逐行進行處理。
首先用strlen()函數(shù)得到當前行所包含的字符個數(shù)。
再利用一個循環(huán)來依次訪問該行中的所有字符。對于每一個字符,先按照題目中的函數(shù)替代關(guān)系"f(p)=p*11 mod 256"計算出相應的fp的值,再用一條if語句判斷該值是否符合本題給定的條件:"計算后f(p)的值小于等于32或f(p)對應的字符是數(shù)字0至9"。如果符合條件,則該字符不變,否則用f(p)所對應的字符對其進行替代。
詞條內(nèi)容僅供參考,如果您需要解決具體問題
(尤其在法律、醫(yī)學等領域),建議您咨詢相關(guān)領域?qū)I(yè)人士。