1002 寫出這個數

2021-10-08 06:39:07 字數 1600 閱讀 6642

剛開始學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...