[pat]1002 写出这个数 (20分)

题目地址
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:

每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10
的100
​​ 。

输出格式:

在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。

输入样例:

1234567890987654321123456789

输出样例:

yi san wu

思路:由于数字达到10的100次方,必须使用数组来存储数据,char a[101],100也行。定义一个二维数组包含0-9的拼音(使用指针数组更简便)num[10][10]。读入数字存在a[i],把每一位相加得sum;把sum的每一位存入数组weishu[i],最后输出每一位的拼音。
【注】有数字转换为拼音:需要两个数组,一个int型数组保存和的每一位,还有一个char*指针数组或char 型二维数组保存0-9的拼音形式,通过下标输出对应的拼音

#include<iostream>
#include<cstring>
using namespace std;
const int maxn=101;
int main(){
	//int a[maxn],num=0;
   char a[maxn];
   int sum=0;      //定义成了char,排错2小时 
   //while(cin>>a[num]) num++;
   char num[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"}; //字符串一定要有"",字符用'' 
   //char *num[]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"}; 
   cin>>a;

//各位数和   
   for(int i=0;i<strlen(a);i++){
   	int nu=a[i]-'0';             //减'0',由字符串变为数字 
   	sum+=nu;
   }
   
   int weishu[4],i=0;         //装和的每一位
//   for(int i=0;i<5;i++){         用for不妥,因为sun长度不一定为5 
//   	b[i]=sum%10;
//   	sum/=10;
//   } 
   while(sum>0){
   	weishu[i]=sum%10;
   	sum/=10;
   	i++;
   } 
   for(int j=i-1;j>=0;j--){
   	cout<<num[weishu[j]];
   	if(j>0) cout<<" ";
   }
   return 0;
}

总结:
1.int是有范围的,大概到10的6次方,超过就使用数组装每一位。
2.二维字符串数组建议使用指针数组代替,更简便,不用考虑定义时的具体数字。
3.a[i]-‘0’; //减’0’,由字符串变为数字

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值