試題 基礎練習 數的讀法(c++ & Python)

試題 基礎練習 數的讀法

資源限制

時間限制:1.0s   內存限制:512.0MB

問題描述

  Tom教授正在給研究生講授一門關於基因的課程,有一件事情讓他頗爲頭疼:一條染色體上有成千上萬個鹼基對,它們從0開始編號,到幾百萬,幾千萬,甚至上億。
  比如說,在對學生講解第1234567009號位置上的鹼基時,光看着數字是很難準確的念出來的。
  所以,他迫切地需要一個系統,然後當他輸入12 3456 7009時,會給出相應的念法:
  十二億三千四百五十六萬七千零九
  用漢語拼音表示爲
  shi er yi san qian si bai wu shi liu wan qi qian ling jiu
  這樣他只需要照着念就可以了。
  你的任務是幫他設計這樣一個系統:給定一個阿拉伯數字串,你幫他按照中文讀寫的規範轉爲漢語拼音字串,相鄰的兩個音節用一個空格符格開。
  注意必須嚴格按照規範,比如說“10010”讀作“yi wan ling yi shi”而不是“yi wan ling shi”,“100000”讀作“shi wan”而不是“yi shi wan”,“2000”讀作“er qian”而不是“liang qian”。

輸入格式

  有一個數字串,數值大小不超過2,000,000,000。

輸出格式

  是一個由小寫英文字母,逗號和空格組成的字符串,表示該數的英文讀法。

樣例輸入

1234567009

樣例輸出

shi er yi san qian si bai wu shi liu wan qi qian ling jiu

 

Python版

num = list(map(int, input()))

wei = {1: 'shi', 2: 'bai', 3: 'qian', 4: 'wan',
       5: 'shi', 6: 'bai', 7: 'qian', 8: 'yi', 9: 'shi'}
yin = {1: 'yi', 2: 'er', 3: 'san', 4: 'si',
       5: 'wu', 6: 'liu', 7: 'qi', 8: 'ba', 9: 'jiu'}

ans = []
for i in range(len(num)):
    if num[i] == 0 and i < len(num) - 1:
        if num[i+1] != 0:
            ans.append('ling')
        continue

    # '10'高位的10的特殊發音處理
    if num[i] == 1 and (len(num)-1-i == 9 or len(num) - 1 - i == 5):
        ans.append('shi')
    else:
        if num[i] in yin:
            ans.append(yin[num[i]])
        if len(num) - 1 - i in wei:
            ans.append(wei[len(num) - 1 - i])

print(*ans)

 

c++版

#include<iostream>
using namespace std;
 
int main(){
    char *num[]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
    char *wei[]={"shi","bai","qian","wan","yi"};
    char *str[20];  //存最後結果
 
    //i:4位數爲一組
    //j:數組str的下標
    //k:n的最後一位數
    int i,j,k,n,l[2]={0};
    i=0;j=0;
    cin>>n;
    while(n>0){
        k=n%10;
        n/=10;
        if(k>0){
            if(i>0){
                if(i>=4 && !l[i/4-1]){  //如果是大於等於4位數的數,且已經加了一個wei,那麼久不要添加
                    l[i/4-1]=1;
                    str[j++]=wei[i/4+2];
                }
                if(i%4!=0){
                    str[j++]=wei[i%4-1];
                }
            }
            str[j++]=num[k];
        }
 
        else if(j>0 && str[j-1]!=num[0]){   //判斷連續另個是不是都是0
            str[j++]=num[0];
        }
 
        i++;
    }
    if(!(str[j-1]=="yi" && j>1 && str[j-2]=="shi"))  //去除yi shi的情況
        cout<<str[j-1]<<" ";        //輸出第一位數
    for(i=j-2;i>=0;i--){        //輸出剩餘的各個字符串
        cout<<str[i]<<" ";
    }
 
    return 0;
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章