亚洲免费乱码视频,日韩 欧美 国产 动漫 一区,97在线观看免费视频播国产,中文字幕亚洲图片

      1. <legend id="ppnor"></legend>

      2. 
        
        <sup id="ppnor"><input id="ppnor"></input></sup>
        <s id="ppnor"></s>

        二級C語言考試輔導(dǎo)教程第四章:數(shù)組[5]

        字號:

        在二維數(shù)組a中選出各行的元素組成一個(gè)一維數(shù)組b。 a=3 16 87 65 4 32 11 108 10 25 12 37b=(87 108 37) 本題的編程思路是,在數(shù)組A的每一行中尋找的元素,找到之后把該值賦予數(shù)組B相應(yīng)的元素即可。程序如下:
             main()
             {
             static int a[][4]={3,16,87,65,4,32,11,108,10,25,12,27};
             int b[3],i,j,l;
             for(i=0;i<=2;i++)
             { l=a[i][0];
             for(j=1;j<=3;j++)
             if(a[i][j]>l) l=a[i][j];
             b[i]=l;}
             printf("\narray a:\n");
             for(i=0;i<=2;i++)
             { for(j=0;j<=3;j++)
             printf("%5d",a[i][j]);
             printf("\n");}
             printf("\narray b:\n");
             for(i=0;i<=2;i++)
             printf("%5d",b[i]);
             printf("\n");
             }
             程序中第一個(gè)for語句中又嵌套了一個(gè)for語句組成了雙重循環(huán)。外循環(huán)控制逐行處理,并把每行的第0列元素賦予l。進(jìn)入內(nèi)循環(huán)后,把l與后面各列元素比較,并把比l大者賦予l。內(nèi)循環(huán)結(jié)束時(shí)l 即為該行的元素,然后把l值賦予b[i]。等外循環(huán)全部完成時(shí),數(shù)組b中已裝入了a各行中的值。后面的兩個(gè) for語句分別輸出數(shù)組a和數(shù)組b。
             輸入五個(gè)國家的名稱按字母順序排列輸出。
               本題編程思路如下:五個(gè)國家名應(yīng)由一個(gè)二維字符數(shù)組來處理。然而C語言規(guī)定可以把一個(gè)二維數(shù)組當(dāng)成多個(gè)一維數(shù)組處理。 因此本題又可以按五個(gè)一維數(shù)組處理, 而每一個(gè)一維數(shù)組就是一個(gè)國家名字符串。用字符串比較函數(shù)比較各一維數(shù)組的大小,并排序, 輸出結(jié)果即可。
             編程如下:
             void main()
             {
             char st[20],cs[5][20];
             int i,j,p;
             printf("input country’s name:\n");
             for(i=0;i<5;i++)
             gets(cs[i]);
             printf("\n");
             for(i=0;i<5;i++)
             { p=i;strcpy(st,cs[i]);
             for(j=i+1;j<5;j++)
             if(strcmp(cs[j],st)<0) {p=j;strcpy(st,cs[j]);}
             if(p!=i)
             {
             strcpy(st,cs[i]);
             strcpy(cs[i],cs[p]);
             strcpy(cs[p],st);
             }
             puts(cs[i]);}printf("\n");
             }
             本程序的第一個(gè)for語句中,用gets函數(shù)輸入五個(gè)國家名字符串。上面說過C語言允許把一個(gè)二維數(shù)組按多個(gè)一維數(shù)組處理, 本程序說明cs[5][20]為二維字符數(shù)組,可分為五個(gè)一維數(shù)組cs[0],cs[1],cs[2],cs[3],cs[4]。因此在gets函數(shù)中使用cs[i]是合法的。 在第二個(gè)for語句中又嵌套了一個(gè)for語句組成雙重循環(huán)。 這個(gè)雙重循環(huán)完成按字母順序排序的工作。在外層循環(huán)中把字符數(shù)組cs[i]中的國名字符串拷貝到數(shù)組st中,并把下標(biāo)i賦予P。 進(jìn)入內(nèi)層循環(huán)后,把st與cs[i]以后的各字符串作比較,若有比st小者則把該字符串拷貝到st中,并把其下標(biāo)賦予p。內(nèi)循環(huán)完成后如p不等于 i 說明有比cs[i]更小的字符串出現(xiàn),因此交換cs[i]和st的內(nèi)容。 至此已確定了數(shù)組cs的第i號元素的排序值。然后輸出該字符串。在外循環(huán)全部完成之后即完成全部排序和輸出。