1002. 写出这个数 (20)

1 篇文章 0 订阅
1 篇文章 0 订阅

PAT (Basic Level) Practise (中文)

1002. 写出这个数 (20)

 

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

 

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

 

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

 

输入样例:

1234567890987654321123456789

输出样例:

yi san wu

 

解题代码如下:

#include<stdio.h> 

 

int main()

{

char a[101] = "0";//定义一个字符串存放这个自然数

int i = 0;

int sum = 0;

int s = 0;

int flag1 = 0;

scanf("%s",a);

while(a[i] != '\0') //将每一位字符转化为数字并求出和

{

sum += a[i] - 48;

i++;

}

s = sum / 100; //处理百位上的数字

switch(s)

{

case 0:flag1 = 1;

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;

}

s = (sum / 10) % 10; //处理十位的数字

switch(s)

{

case 0:

if(flag1 == 1)

{

break;

}

else

{

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;

}

s = sum % 10; //处理个位上的数字

switch(s)

{

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;

}

return 0;

}

 

代码分析:

这道题,总的来说在逻辑上并不困难,只是最后再输出格式上需要我们认真一些,不要多输出、或者少输出了“空格”。

需要注意的地方:

这个自然数的数值也许会比较大,普通的int或者long int并不能存储。所以我们需要用字符串来储存,但是字符中的数字以ASCII码的形式存储,与整形变量的‘1’的值并不相同,所以要做数值上的转换。

 

在这里有许多人也许会问,为什么个位、十位、百位、上的数字要分开来处理,放在一个循环中岂不是能省去更多的空间?其实最后的输出格式才是这道题的精髓之处。

第一:如果百位是0,则不输出。如果百位是0,十位也是0,则都不输出,个位上的数一定要输出。所以即使简化了switch中的代码(将其写在一个函数中),我们也要把百位十位有关‘0’的处理分开来处理,虽然能是代码量变短,但这也使让代码更加难读。

第二:每个拼音之间要用空格分开,空格不能多不能少。

 

 

总结:

一、有的时候代码长不代表代码质量不好,缩短代码的长度只是为了增加代码的可读性。不要盲目的想缩短代码而不注重代码的可读性。

二、认真分析题目中给出的信息:“这里保证n小于10的100次方”,是题目中的原话,这告诉我们最后各个数位上的数字相加之和最多是一个三位数。所以在写代码的时候只需要考虑百位、十位、个位,这三位就OK了。

所以我们在平时做项目的时候一定要看到实际的状况是什么样的,怎样可以简化我们的代码,除去不必要的分析和计算。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值