题目地址
读入一个正整数 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’,由字符串变为数字