亚洲欧洲国产欧美一区精品,激情五月亚洲色五月,最新精品国偷自产在线婷婷,欧美婷婷丁香五月天社区

      自考

      各地資訊
      當(dāng)前位置:華課網(wǎng)校 >> 自考 >> 模擬試題 >> 工學(xué)類 >> C語(yǔ)言程序設(shè)計(jì) >> 文章內(nèi)容

      排行熱點(diǎn)

      • 歷年真題
      • 模擬試題
      • 自考自答

      自學(xué)考試《C語(yǔ)言程序設(shè)計(jì)》復(fù)習(xí)題及答案_第2頁(yè)

      來(lái)源:華課網(wǎng)校  [2017年1月31日]  【

        【4.1】參考答案:

        #include

        main( )

        { int year;

        float money,rate,total; /* money:本金 rate:月利率 total:本利合計(jì)*/

        printf("Input money and year =?");

        scanf("%f%d", &money, &year); /* 輸入本金和存款年限 */

        if(year==1) rate=0.00315; /* 根據(jù)年限確定利率 */

        else if(year==2) rate=0.00330;

        else if(year==3) rate=0.00345;

        else if(year==5) rate=0.00375;

        else if(year==8) rate=0.00420;

        else rate=0.0;

        total=money + money * rate * 12 * year; /* 計(jì)算到期的本利合計(jì) */

        printf(" Total = %.2f\n", total);

        }

        【4.2】參考答案:

        #include

        main( )

        { int year, month, days;

        printf("Enter year and month:");

        scanf("%d%d", &year, &month);

        switch (month)

        { case 1: case 3: case 5: case 7: case 8: case 10: case 12:

        days=31; break; /* 處理"大"月 */

        case 4: case 6: case 9: case 11:

        days=30; break; /* 處理"小"月 */

        case 2: if(year%4==0&&year%100!=0 || year%400==0)

        days=29; /* 處理閏年平月 */

        else days=28; /* 處理不是閏年平月 */

        break;

        default: printf("Input error!\n"); /* 月份錯(cuò)誤 */

        days=0;

        }

        if( days!=0 )

        printf("%d, %d is %d days\n", year, month, days);

        }

        【4.3】參考答案:

        #include

        main ( )

        { float data1, data2; /* 定義兩個(gè)操作數(shù)變量 */

        char op; /* 操作符 */

        printf("Enter your expression:");

        scanf("%f%c%f", &data1, &op, &data2); /* 輸入表達(dá)式 */

        switch(op) /* 根據(jù)操作符分別進(jìn)行處理 */

        { case '+' : /* 處理加法 */

        printf("%.2f+%.2f=%.2f\n", data1, data2, data1+data2); break;

        case '-' : /* 處理減法 */

        printf("%.2f-%.2f=%.2f\n", data1, data2, data1-data2); break;

        case '*' : /* 處理乘法 */

        printf("%.2f*%.2f=%.2f\n", data1, data2, data1*data2); break;

        case '/' : /* 處理除法 */

        if( data2==0 ) /* 若除數(shù)為0 */

        printf("Division by zero.\n");

        else

        printf("%.2f/%.2f=%.2f\n", data1, data2, data1/data2);

        break;

        default: /* 輸入了其它運(yùn)算符 */

        printf("Unknown operater.\n");

        }

        }

        【4.4】分析:打印此圖形用兩重循環(huán)實(shí)現(xiàn)。

        圖形要重復(fù)n行,故采用循環(huán)結(jié)構(gòu)實(shí)現(xiàn)循環(huán)n次,循環(huán)體內(nèi)部打印一行'*'號(hào),把上述思路表示為:

        for(i=1;i<=n;i++)

        打印一行'*'號(hào);

        每行有n個(gè)'*'號(hào),再采用循環(huán)結(jié)構(gòu)實(shí)現(xiàn)n次循環(huán),循環(huán)內(nèi)部用格式輸出語(yǔ)句打印一個(gè)'*'號(hào),即:

        for(j=1;j<=n;j++)

        printf("*");

        按照上述思路,實(shí)現(xiàn)打印矩形。

        參考答案:

        main()

        { int i,j,n;

        printf("\nPlease Enter n:");

        scanf("%d",&n);

        for(i=1;i<=n;i++)

        { for(j=1;j<=n;j++)

        printf("*");

        printf("\n");

        }

        }

        【4.5】分析:此圖形和上題的區(qū)別在于在每一行先要打印空格,然后再打印n個(gè)'*'號(hào),在上題第一層循環(huán)體內(nèi)打印'*'號(hào)的循環(huán)前面增加一個(gè)循環(huán)打印空格。每行空格的個(gè)數(shù)是逐行減少的,由于第一層循環(huán)的控制變量i是逐行增1,所以用一個(gè)固定值的數(shù)減去i就可實(shí)現(xiàn)對(duì)空格個(gè)數(shù)的控制,在此題中固定值可使用變量n。

        參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n:");

        scanf("%d",&n);

        for(i=1;i<=n;i++)

        { for(j=1;j<=n-i;j++)

        printf(" ");

        for(j=1;j<=n;j++)

        printf("*");

        printf("\n");

        }

        }

        【4.6】分析:此題和上題的區(qū)別在于每行'*'的數(shù)量逐行減少,可以使用上題控制空格個(gè)數(shù)的思路來(lái)控制'*'號(hào)的個(gè)數(shù),請(qǐng)注意每行'*'的個(gè)數(shù)都是奇數(shù)。

        參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n:");

        scanf("%d",&n);

        for(i=1;i<=n;i++)

        { for(j=1;j<=n-i;j++)

        printf(" ");

        for(j=1;j<=2*i-1;j++)

        printf("*");

        printf("\n");

        }

        }

        【4.7】分析:此題圖形是第3題圖形的垂直反轉(zhuǎn),在編程上我們可以變換一個(gè)思路。對(duì)于圖形中的第i行(1≤i≤n),共需要輸出2n-i個(gè)字符,其中前面的i-1個(gè)字符為空格,后面的字符為'*'號(hào)。按照這一思路可以編寫出如下程序。

        參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n:");

        scanf("%d", &n);

        for( i=1;i<=n;i++ ) /* 重復(fù)輸出圖形的n行 */

        { for( j=1;j<=2*n-i;j++ ) /* 重復(fù)輸出圖形一行中的每個(gè)字符 */

        if(j<=i-1) printf(" "); /* 輸出前面的空格 */

        else printf("*"); /* 輸出后面的*號(hào) */

        printf("\n");

        }

        }

        【4.8】分析:此題和第3題的區(qū)別僅是每行的'*'個(gè)數(shù)增加n-1個(gè)。

        參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n:");

        scanf("%d",&n);

        for(i=1;i<=n;i++)

        { for(j=1;j<=n-i;j++)

        printf(" ");

        for(j=1;j<=2*i-1+(n-1);j++)

        printf("*");

        printf("\n");

        }

        }

        【4.9】分析:對(duì)于空心圖形,我們可以在上題的基礎(chǔ)上,對(duì)于打印'*'號(hào)的循環(huán)進(jìn)行修改,僅在循環(huán)開始值(j=1)和循環(huán)結(jié)束值(j=2*(i-1)+n)時(shí)打印'*'號(hào),其它位置都打印空格。另一種思路是將每行打印的空格和'*'的兩個(gè)循環(huán)合為一體考慮,在判斷出需要打印'*'的兩個(gè)位置及第一行和最后一行相應(yīng)位置外,其余位置都打印空格。

        參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n:");

        scanf("%d",&n);

        for(i=1;i<=n;i++)

        { for(j=1;j<=2*n+i-3;j++)

        if(j==n-i+1 || j>n-i+1 && (i==1||i==n)) printf("*");

        else printf(" ");

        printf("*\n");

        }

        }

        【4.10】分析:此圖形可以理解為兩個(gè)空心梯形反向連接而成,因此可以利用上題的思路進(jìn)行輸出。

        參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n:");

        scanf("%d",&n);

        for(i=1;i<=n;i++) /* 輸出圖形的上半部分(含中心行) */

        { for(j=1;j<=2*n-i-1;j++)

        if(j==i) printf("*");

        else printf(" ");

        printf("*\n");

        }

        for(i=1;i

        { for(j=1;j<=n+i;j++)

        if(j==n-i) printf("*");

        else printf(" ");

        printf("*\n");

        }

        }

        【4.11】分析:此題與上題的區(qū)別在于打印'*'號(hào)的位置不同,編程時(shí)要找出應(yīng)打印'*'號(hào)的位置和兩個(gè)循環(huán)變量i、j以及行數(shù)n的關(guān)系。

        參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n:");

        scanf ("%d", &n);

        for(i=1;i<=n;i++) /* 輸出圖形的上半部分(含中心行) */

        { for(j=1;j<=2*n-i;j++)

        if(j==n-i+1 || j>n-i+1 && i==1) printf("*");

        else printf(" ");

        printf("*\n");

        }

        for(i=1;i

        { for(j=1;j<=3*(n-1)-i;j++)

        if(j==i+1 || j>i+1 && i==n-1) printf("*");

        else printf(" ");

        printf("*\n");

        }

        }

        【4.12】參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n:");

        scanf("%d",&n);

        for(i=1;i<=n;i++)

        { for(j=1;j<=n;j++)

        if(j==n-i+1 || i==1 || i==n) printf("*");

        else printf(" ");

        printf("\n");

        }

        }

        【4.13】參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n: ");

        scanf("%d", &n);

        for(i=1;i<=n;i++) /* 輸出圖形的上半部分(含中心行) */

        { for(j=1;j<=n-i;j++)

        if(j==1 || j==n-i+1) printf("* ");

        else printf(" ");

        printf("\n");

        }

        for(i=1;i

        { for(j=1;j<=i+1;j++)

        if(j==1 || j==i+1) printf("* ");

        else printf(" ");

        printf("\n");

        }

        }

        【4.14】參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n: ");

        scanf("%d",&n);

        for(i=1;i<=n;i++)

        { for(j=1;j<=n;j++)

        if(j==1 || j==i || j==n) printf("*");

        else printf(" ");

        printf("\n");

        }

        }

        【4.15】參考答案:

        main( )

        { int i,j,n;

        printf("\nPlease Enter n: ");

        scanf("%d",&n);

        for(i=1;i<=n;i++)

        { for(j=1;j<=n+i-1;j++)

        if(j>n-i) printf("*");

        else printf(" ");

        printf("\n");

        }

        for(i=1;i

        { for(j=1;j<=2*n-i-1;j++)

        if(j>i) printf("*");

        else printf(" ");

        printf("\n");

        }

        }

      責(zé)編:zhangjing0102