0
点赞
收藏
分享

微信扫一扫

PTA1002 写出这个数

at小涛 2022-07-18 阅读 51


PTA1002 写出这个数

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

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

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

输入样例:
1234567890987654321123456789
输出样例:
yi san wu
作者
CHEN, Yue
单位
浙江大学
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB

斜体样式我原来没考虑到数字太大的问题,所以我就这样写的:(但我的问题就只有这一个,有点长)

#include<stdio.h>
#include<math.h>
int main(){

long long n;
scanf("%lld",&n);
int sum=0;
// printf("%lld\n",n);
while(n){ //求各位之和
sum+=(n%10);
n/=10;

}
int y;
y=sum; //把sum存入y;
// printf("sum=%d\n",sum);

int len=0; //计和有多少位 //log10(sum)+1也行
while(sum){
sum/=10;
len++;
}
// printf("len=%d\n",len);

sum=y; //恢复sum的值
// printf("sum=%d\n",sum);

int num[3]; //和最多是900,三位数
int i,j;

for(i=0;i<len;i++){ //从个位开始存在数组num[]中
sum/=pow(10,i);
num[i]=sum%10;
}

// for(i=0;i<len;i++){
// printf("%d,,",num[i]);
// }

int temp ,m; //逆序存数组 num[]
m=(len-1)/2;
for(i=0;i<=m;i++)
{
j=len-1-i;

temp=num[i];
num[i]=num[j];
num[j]=temp;

}

// for(i=0;i<len;i++){
// printf("%d..",num[i]);
// }

for(i=0;i<len;i++){ //念数字
if(i==0){ //第一位格式为x ,以后的是空格x
switch(num[i]){ //这样就符合格式了
case 0:printf("ling");break;
case 1:printf("yi");break;
case 2: printf ("er");break;
case 3: printf ("san");break;
case 4: printf ("si");break;
case 5: printf ("wu");break;
case 6: printf ("liu");break;
case 7: printf ("qi");break;
case 8: printf("ba");break;
case 9: printf("jiu");break;
}
}
else{
switch(num[i]){
case 0:printf(" ling");break;
case 1:printf(" yi");break;
case 2: printf (" er");break;
case 3: printf (" san");break;
case 4: printf (" si");break;
case 5: printf (" wu ");break;
case 6: printf (" liu");break;
case 7: printf (" qi ");break;
case 8: printf(" ba");break;
case 9: printf(" jiu");break;
}
}
}

printf("\n");
for(i=0;i<len;i++){ //念数字

switch(num[i]){
case 0:printf("ling");break;
case 1:printf("yi");break;
case 2: printf ("er");break;
case 3: printf ("san");break;
case 4: printf ("si");break;
case 5: printf ("wu");break;
case 6: printf ("liu");break;
case 7: printf ("qi");break;
case 8: printf("ba");break;
case 9: printf("jiu");break;

}
if(i!=len){
printf(" ");
}

}
}

下面是我搜大神写的:

#include <stdio.h>
int ctoi(char num){//把一个char型数字,转化成int
return num - '0';
}
int main(){
int store[3];//store各位保存一个count的位数,因为count之和最大不过900,所以三位就够用
char num[100];//为了能够存下10^100,这么大个数。而C语言中整型数据类型没有能存得下的
scanf("%s",&num);
int i = 0;
int count = 0;
while(num[i] != '\0'){
count += ctoi(num[i]); //变为数字 求和
i ++;
}
for(i = 0;count;i ++){ //各位
store[i] = count % 10;
count /= 10;
}
i--; //i=i-1;初始值
for(;i >= 0;i --){
switch(store[i]){
case 0:
printf("ling");break;
case 1:
printf("yi");break;
case 2:
printf("er");break;
case 3:
printf("san");break;
case 4:
printf("si");break;
case 5:
printf("wu");break;
case 6:
printf("liu");break;
case 7:
printf("qi");break;
case 8:
printf("ba");break;
case 9:
printf("jiu");break;
}
// if (store[i] != '\0')//此处尤为精妙,也是我没有意料到的
// printf(" ");
// else{
// printf("\n");
//}
if(i!=0){
printf(" ");}

}
}


举报

相关推荐

0 条评论