剛開始學c,記錄一下
讀入乙個正整數 n,計算其各位數字之和,用漢語拼音寫出和的每一位數字。
輸入格式:
每個測試輸入包含 1 個測試用例,即給出自然數 n 的值。這裡保證 n 小於 10
100
。
輸出格式:
在一行內輸出 n 的各位數字之和的每一位,拼音數字間有 1 空格,但一行中最後乙個拼音數字後沒有空格。
輸入樣例:
1234567890987654321123456789
輸出樣例:
yi san wu
這個題邊寫邊修改,沒看參考,花了乙個多小時,簡單說下遇到的問題和思路
1、如何儲存這麼大的資料,想了一小會,發現無論什麼int,long什麼的都行不通,得用字元陣列
2、一開始寫完後,直接對sum(每位數的和)取餘得到每一位,再轉換成拼音,發現135逆序輸出「wu san yi」了,是我天真了2333
3、思考怎麼正序得到sum的每一位,試了下遞迴
void order(int sum)
發現只能正序輸出每一位,卻不能轉換成拼音;即便轉換成拼音,也沒法搞定拼音後的空格
又開始想將sum分解
count=1;
while(sum>0)
再用sum和count迴圈 相除、取餘 爭取得到每一位
4、上面的方法還是難整,不得行。突然靈光一閃,用陣列儲存sum取餘後的每一位,再逆序輸出轉換成拼音,哈哈哈哈
經過一番除錯,程式如下
#includevoid print(int n);
int main(void)
/*printf("i:%d\n",i);
for(i=0;i<10;i++)
printf("%d ",a[i]);*/一段除錯**,忽略即可
while(i-->0)//注意,陣列是從0開始放資料的哦
return 0;
}void print(int n)//轉換成拼音
}
當然啦,寫完程式必須得學習學習別人的思路和寫法。看了兩篇文章,有用到堆、棧和sprintf函式的,都不是我這小白了解的東西,也就沒細看。但是,轉換拼音別有用二維字元陣列,覺著不錯,稍微改編了一下
#includeint count(int n);
void print(int n);
void out(int n);
int main(void)
;/*用指標陣列,沒用二維陣列,顯得我是學過指標的【狗頭】*/
int digit,sum,i,a[10];
i=sum=0;
while((s[i]=getchar())!='\n')
i++;
s[i]='\0';
for(i=0;s[i]!='\0';i++)
sum+=s[i]-'0';
if(sum>99)
else if(sum>9)
else
return 0;
}
總結:陣列真是個好東西 1002 寫出這個數
本題是pat乙級真題 思路 題目本來是大數的問題,但是由於只求各位之和,就可以邊輸入邊處理。訓練目的 字串的運用 讀入乙個自然數n,計算其各位數字之和,用漢語拼音寫出和的每一位數字。輸入格式 每個測試輸入包含1個測試用例,即給出自然數n的值。這裡保證n小於10100。輸出格式 在一行內輸出n的各位數...
1002寫出這個數
時間限制 400 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 chen,yue 讀入乙個自然數n,計算其各位數字之和,用漢語拼音寫出和的每一位數字。輸入格式 每個測試輸入包含1個測試用例,即給出自然數n的值。這裡保證n小於10100。輸出格式 在一行...
1002 寫出這個數
讀入乙個自然數n,計算其各位數字之和,用漢語拼音寫出和的每一位數字。輸入格式 每個測試輸入包含1個測試用例,即給出自然數n的值。這裡保證n小於10100。輸出格式 在一行內輸出n的各位數字之和的每一位,拼音數字間有1 空格,但一行中最後乙個拼音數字後沒有空格。輸入樣例 123456789098765...