2013年計(jì)算機(jī)等考三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題及答案(6)

字號(hào):

為大家收集整理了《2013年計(jì)算機(jī)等考三級(jí)網(wǎng)絡(luò)技術(shù)上機(jī)題及答案(6)》供大家參考,希望對(duì)大家有所幫助!??!
    函數(shù)ReadDat( )的功能是實(shí)現(xiàn)從文件ENG56.IN中讀取一篇英文文章,存入到字符串?dāng)?shù)組xx中。請(qǐng)編制函數(shù)encryChar( ),按給定的替代關(guān)系對(duì)數(shù)組xx中所有字符進(jìn)行替代,仍存入數(shù)組xx的對(duì)應(yīng)的位置上,最后調(diào)用函數(shù)WriteDat( )把結(jié)果xx輸出到文件ps56.dat中。
    替代關(guān)系:f(p)=p*11 mod 256(p是數(shù)組xx中某一個(gè)字符的ASCII值,f(p)是計(jì)算后新字符的ASCII值),如果原字符是小寫(xiě)字母或計(jì)算后f(p)的值小于等于32,則該字符不變,否則將f(p)所對(duì)應(yīng)的字符進(jìn)行替代。
    注意:部分源程序已給出,原始數(shù)據(jù)文件的存放格式是每行的寬度均小于80個(gè)字符。
    請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)ReadDat()和寫(xiě)函數(shù)WriteDat()的內(nèi)容。
    試題程序:
    #include
    #include
    #include
    #include
    unsigned char xx[50][80];
    int maxline=0;
    int ReadDat(void);
    void WriteDat(void);
    void encryChar()
    {
    }
    void main()
    {
    system("CLS");
    if(ReadDat())
    {
    printf("數(shù)據(jù)文件ENG56.IN不能打開(kāi)!\n\007");
    return;
    }
    encryChar();
    WriteDat();
    }
    int ReadDat(void)
    {
    FILE *fp;
    int i=0;
    unsigned char *p;
    if((fp=fopen("ENG56.IN","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;
    fp= fopen("ps56.dat","w");
    for(i=0;i
    {
    printf("%s\n",xx[i]);
    fprintf(fp,"%s\n",xx[i]);
    }
    fclose(fp);
    }
    【答案】
    void encryChar()
    {
    int i,j; /*定義循環(huán)控制變量*/
    int str; /*存儲(chǔ)字符串的長(zhǎng)度*/
    char ch; /*存儲(chǔ)當(dāng)前取得的字符*/
    for(i=0;i
    {
    str=strlen(xx[i]); /*求得當(dāng)前行的字符串長(zhǎng)度*/
    for(j=0;j
    {
    ch=xx[i][j] *11%256;
    if((xx[i][j]>='a' && xx[i][j]<='z') || ch<=32)
    /*如果原字符是小寫(xiě)字母或計(jì)算后的值小于等于32*/
    continue; /*則不作改變,指向下一個(gè)字符*/
    else
    xx[i][j]=ch; /*否則用新字符取代原有字符*/
    }
    } 
    }
    【解析】本題要對(duì)二維數(shù)組中的字符元素按行進(jìn)行處理。
    首先用strlen()函數(shù)得到當(dāng)前行所包含的字符個(gè)數(shù)。
    然后再利用一個(gè)循環(huán)來(lái)依次訪(fǎng)問(wèn)該行中的所有字符。對(duì)于每一個(gè)字符,先按照題目中的函數(shù)替代關(guān)系"f(p)=p*11 mod 256"計(jì)算出相應(yīng)的fp值,再用一條if語(yǔ)句判斷該值是否符合本題給定的條件:"原字符是小寫(xiě)字母或計(jì)算后的值小于等于32"。如果符合條件,則該字符不變,否則用f(p)所對(duì)應(yīng)的字符對(duì)其進(jìn)行替代。