讀入乙個自然數n,計算其各位數字之和,用漢語拼音寫出和的每一位數字。
輸入格式:每個測試輸入包含1個測試用例,即給出自然數n的值。這裡保證n小於10的100次方。
輸出格式:在一行內輸出n的各位數字之和的每一位,拼音數字間有1 空格,但一行中最後乙個拼音數字後沒有空格。
輸入樣例:
1234567890987654321123456789
輸出樣例:
yi san wu
題目分析:
計算數字n中各個位的數字之和,理解起來很容易,只需將數字n各個位數字分離,然後相加即可,但是題目存在幾個棘手的地方:
1. n的範圍不超過10的100次方,因此普通資料型別例如int之類的肯定會爆掉,因此只能選擇字元陣列去解決。
2. 最後是以漢字拼音輸出乙個數,每個數之間都有空格,但是最後乙個數後不能有空格,首先,我想到了先用for迴圈去處理,每次輸出乙個數+空格,最後一次的話,利用/b退格鍵來處理,可是pat的oj似乎不支援還是其他問題,直接給我答案錯誤,無奈,最終用switch加if,解決這個問題。
偽**如下:
//用字串存入n,並且各個位相加,總和為sum
for(i=0;isum=sum+num[i]-'0';
temp=sum;
}//統計sum的位數
while(sum)
sum/=10;
cot++
//將sum的每一位存入乙個新的陣列
for(i=count-1;i>=0;i--)
//用for+switch語句去輸出相應的漢語拼音
for ( i = 0; i < count; i++)
ac**如下:
#include
#include
#define maxn 100
int main()
; int num1[maxn]=;
int sum=0,i;
int count=0;
gets(num);
for(i=0;isum=sum+num[i]-'0';//加起來是多少。ps:減0即減48,詳見ascii碼表
int temp=sum;
while(temp)//這個數有多少位
//分離從個位開始,從右往左,故迴圈採用逆迴圈
for(i=count-1;i>=0;i--)
for ( i = 0; i < count; i++)
if(i!=count-1)//如果當前非最後一位,則輸出空格
printf(" ");
}}
PAT 乙 1002 寫出這個數 20
讀入乙個自然數n,計算其各位數字之和,用漢語拼音寫出和的每一位數字。輸入格式 每個測試輸入包含1個測試用例,即給出自然數n的值。這裡保證n小於10100。輸出格式 在一行內輸出n的各位數字之和的每一位,拼音數字間有1 空格,但一行中最後乙個拼音數字後沒有空格。輸入樣例 123456789098765...
PAT乙1002 寫出這個數 20
題目在這裡 時間限制 400 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 chen,yue 讀入乙個自然數n,計算其各位數字之和,用漢語拼音寫出和的每一位數字。輸入格式 每個測試輸入包含1個測試用例,即給出自然數n的值。這裡保證n小於10100。輸出...
PAT乙 1002 寫出這個數 20分
讀入乙個正整數 n,計算其各位數字之和,用漢語拼音寫出和的每一位數字。每個測試輸入包含 1 個測試用例,即給出自然數 n 的值。這裡保證 n 小於 10 100 在一行內輸出 n 的各位數字之和的每一位,拼音數字間有 1 空格,但一行中最後乙個拼音數字後沒有空格。123456789098765432...