PAT甲级题解-1100. Mars Numbers (20)-字符串处理
生活随笔
收集整理的這篇文章主要介紹了
PAT甲级题解-1100. Mars Numbers (20)-字符串处理
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
沒什么好說的,注意字符串的處理,以及當數字是13的倍數時,只需高位叫法的單詞。比如26,是“hel”,而不是“hel tret”。
代碼:
#include <iostream> #include <cstdio> #include <algorithm> #include <map> #include <string> #include <string.h> using namespace std; char mars1[13][20]={"tret","jan", "feb", "mar", "apr", "may", "jun", "jly", "aug", "sep", "oct", "nov", "dec"}; char mars2[13][20]={"","tam", "hel", "maa", "huh", "tou", "kes", "hei", "elo", "syy", "lok", "mer", "jou"}; map<char*,int>maps;int main() {int n;char str[20];int decade,digit;scanf("%d",&n);getchar();for(int i=0;i<n;i++){gets(str);if('0'<=str[0]&&str[0]<='9'){int num=atoi(str);if(num/13 && num%13==0){//注意整除的情況。。。printf("%s\n",mars2[num/13]);}else if(num/13){decade=num/13;digit=num%13;printf("%s %s\n",mars2[decade],mars1[digit]);}else{printf("%s\n",mars1[num]);}}else{int len=strlen(str);//如果是一個字符串的話,加上\0頂多4位。不過要注意也要比較下十位數if(len<5){digit=-1;for(int i=0;i<13;i++){if(strcmp(str,mars1[i])==0){digit=i;break;}}if(digit==-1){for(int i=1;i<13;i++){if(strcmp(str,mars2[i])==0){decade=i;break;}}printf("%d\n",decade*13);}elseprintf("%d\n",digit);}else{char tmp[20];int i;for(i=0;i<len && str[i]!=' ';i++){tmp[i]=str[i];}tmp[i]='\0';//十位數for(int k=1;k<13;k++){if(strcmp(tmp,mars2[k])==0){decade=k;break;}}i++;int p=0;for(;i<len;i++,p++)tmp[p]=str[i];tmp[p]='\0';//個位數for(int k=0;k<13;k++){if(strcmp(tmp,mars1[k])==0){digit=k;break;}}printf("%d\n",decade*13+digit);}}}return 0; } View Code?
轉載于:https://www.cnblogs.com/chenxiwenruo/p/6102581.html
總結
以上是生活随笔為你收集整理的PAT甲级题解-1100. Mars Numbers (20)-字符串处理的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C语言 · 前缀表达式
- 下一篇: easy ui datagrid