【4.1】參考答案:
#include
main( )
{ int year;
float money,rate,total; /* money:本金 rate:月利率 total:本利合計*/
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; /* 計算到期的本利合計 */
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"); /* 月份錯誤 */
days=0;
}
if( days!=0 )
printf("%d, %d is %d days\n", year, month, days);
}
【4.3】參考答案:
#include
main ( )
{ float data1, data2; /* 定義兩個操作數(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: /* 輸入了其它運算符 */
printf("Unknown operater.\n");
}
}
【4.4】分析:打印此圖形用兩重循環(huán)實現(xiàn)。
圖形要重復(fù)n行,故采用循環(huán)結(jié)構(gòu)實現(xiàn)循環(huán)n次,循環(huán)體內(nèi)部打印一行'*'號,把上述思路表示為:
for(i=1;i<=n;i++)
打印一行'*'號;
每行有n個'*'號,再采用循環(huán)結(jié)構(gòu)實現(xiàn)n次循環(huán),循環(huán)內(nèi)部用格式輸出語句打印一個'*'號,即:
for(j=1;j<=n;j++)
printf("*");
按照上述思路,實現(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個'*'號,在上題第一層循環(huán)體內(nèi)打印'*'號的循環(huán)前面增加一個循環(huán)打印空格。每行空格的個數(shù)是逐行減少的,由于第一層循環(huán)的控制變量i是逐行增1,所以用一個固定值的數(shù)減去i就可實現(xiàn)對空格個數(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ù)量逐行減少,可以使用上題控制空格個數(shù)的思路來控制'*'號的個數(shù),請注意每行'*'的個數(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),在編程上我們可以變換一個思路。對于圖形中的第i行(1≤i≤n),共需要輸出2n-i個字符,其中前面的i-1個字符為空格,后面的字符為'*'號。按照這一思路可以編寫出如下程序。
參考答案:
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ù)輸出圖形一行中的每個字符 */
if(j<=i-1) printf(" "); /* 輸出前面的空格 */
else printf("*"); /* 輸出后面的*號 */
printf("\n");
}
}
【4.8】分析:此題和第3題的區(qū)別僅是每行的'*'個數(shù)增加n-1個。
參考答案:
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】分析:對于空心圖形,我們可以在上題的基礎(chǔ)上,對于打印'*'號的循環(huán)進(jìn)行修改,僅在循環(huán)開始值(j=1)和循環(huán)結(jié)束值(j=2*(i-1)+n)時打印'*'號,其它位置都打印空格。另一種思路是將每行打印的空格和'*'的兩個循環(huán)合為一體考慮,在判斷出需要打印'*'的兩個位置及第一行和最后一行相應(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】分析:此圖形可以理解為兩個空心梯形反向連接而成,因此可以利用上題的思路進(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ū)別在于打印'*'號的位置不同,編程時要找出應(yīng)打印'*'號的位置和兩個循環(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"); } }