【PAT】1005 Spell It Right (20 分)——字符串处理

//要么处理字符串,要么就数字分解,都想到了没有有效组合
//我的解法1:加法结果还是int,最后逆序分解数字,按序插入

#include <iostream>
#include <string>
using namespace std;

string num[10]={"zero","one","two","three","four","five",
"six","seven","eight","nine"};

int main(){
  string N;
  getline(cin,N);

  int sum=0;
  for(int i=0;i<N.length();i++){
    sum+=(N[i]-'0');
  }

  int space_flag=0;
  int a=sum,b;
  string res="";

  if(a==0) res="zero";//不优雅,竟然还有特判

  while(a){
    b=a%10;
    if(space_flag) res.insert(0,num[b]+" ");
    else{
      res.insert(0,num[b]);
      space_flag=1;
    }
    a=a/10;
  }

  cout<<res;

  return 0;
}
//我的解法2:加法结果还是int,最后逆序分解数字,再reverse容器
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;

string num[10]={"orez","eno","owt","eerht","ruof","evif",
"xis","neves","thgie","enin"};

int main(){
  string N;
  getline(cin,N);

  int sum=0;
  for(int i=0;i<N.length();i++){
    sum+=(N[i]-'0');
  }

  int space_flag=0;
  int a=sum,b;
  string res="";
    
 if(a==0) res="orez";//特判
  while(a){
    b=a%10;
    if(space_flag) res+=(" "+num[b]);
    else{
      res+=num[b];
      space_flag=1;
    }
    a=a/10;
  }

  reverse(res.begin(),res.end());

  cout<<res;

  return 0;
}
//柳姐解法,柳姐喜欢hash
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;

string num[10]={"zero", "one", "two", "three", "four", "five", "six",
"seven", "eight", "nine"};

int main(){
  string N;
  getline(cin,N);

  int sum=0;
  for(int i=0;i<N.length();i++){
    sum+=(N[i]-'0');
  }

 string res=to_string(sum);//to_string()在PAT是可以用的

  cout<<num[res[0]-'0'];//柳姐不用space_flag
  for(int i=1;i<res.length();i++){
    cout<<" "<<num[res[i]-'0'];
  }

  return 0;
}

总体利用字符串处理还是可读性比较强,而且逻辑简洁。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值