1002.读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字

(代码参照https://blog.csdn.net/linghugoogle/article/details/52728025?locationNum=1&fps=1)

#include<iostream>
using namespace std;
	void pinYin(int a){
	switch(a){
	case 0:cout<<"ling";break;
	case 1:cout<<"yi";break;
	case 2:cout<<"er";break;
	case 3:cout<<"san";break;
	case 4:cout<<"si";break;
	case 5:cout<<"wu";break;
	case 6:cout<<"liu";break;
	case 7:cout<<"qi";break;
	case 8:cout<<"ba";break;
	case 9:cout<<"jiu";break;
	}
	}
int main()
{
   char a[101];
   cin>>a;
   int sum=0;
   int i=0;
   while(a[i]!='\0')
   {
	   sum +=a[i]-'0';
	   i++;
   }
   int b[11];
   int j=0;
   if(sum==0)
   {
      pinYin(0);
	   return 0;
   }

   while(sum!=0)
   {
	   b[j]=sum%10;
	   sum=sum/10;
	   j++;
   }
   for(i=j-1;i>0;--i)
   {
	   pinYin(b[i]);
	   cout<<" ";
   
   }
   pinYin(b[0]);
 

  return 0;
}
```

总结:1.sum +=a[i]-‘0’; 原来是把字符转换成数字(ACSII) ‘0’的ACSII为48
2.a[i]!=’\0’ 判断下一个字符是否是换行符

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值