1002 写出这个数

刚开始学C,记录一下

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

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

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

输入样例:
1234567890987654321123456789
输出样例:
yi san wu

这个题边写边修改,没看参考,花了一个多小时,简单说下遇到的问题和思路

1、如何保存这么大的数据,想了一小会,发现无论什么int,long什么的都行不通,得用字符数组
2、一开始写完后,直接对sum(每位数的和)取余得到每一位,再转换成拼音,发现135逆序输出“wu san yi”了,是我天真了2333
3、思考怎么正序得到sum的每一位,试了下递归

void order(int sum)
{
	if(n<10)
		;
	else
		order(n/10);//先递归,再输出 
	
	printf("%d\n",n%10);
}

发现只能正序输出每一位,却不能转换成拼音;即便转换成拼音,也没法搞定拼音后的空格
又开始想将sum分解

count=1;
while(sum>0)
{
	count*=10;
	sum/=10;
}
再用sum和count循环 相除、取余 争取得到每一位

4、上面的方法还是难整,不得行。突然灵光一闪,用数组保存sum取余后的每一位,再逆序输出转换成拼音,哈哈哈哈
经过一番调试,程序如下

#include<stdio.h>
void print(int n);
int main(void)
{
	char s[100];
	int digit,sum,i,a[10];
	i=sum=0;
	
	while((s[i]=getchar())!='\n')//scanf("%s",s)和gets(s)有时用不好,就用while吧
		i++;
	s[i]='\0';	
	
	
	for(i=0;s[i]!='\0';i++)//求所有位数的和
		sum+=s[i]-'0';
	
	i=0;
	while(sum>0)//把sum取余,保存在数组中
	{
		digit=sum%10;
		a[i++]=digit;
		sum/=10;
	}
	
	/*printf("i:%d\n",i);
	for(i=0;i<10;i++)
		printf("%d ",a[i]);*/一段调试代码,忽略即可
	while(i-->0)//注意,数组是从0开始放数据的哦
	{
		print(a[i]);
		if(i>0)
			printf(" ");
	}
	
	return 0;
}


void print(int n)//转换成拼音
{
	switch(n)
	{
		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;
		default:break;
	}
}

当然啦,写完程序必须得学习学习别人的思路和写法。看了两篇文章,有用到堆、栈和sprintf函数的,都不是我这小白了解的东西,也就没细看。但是,转换拼音别有用二维字符数组,觉着不错,稍微改编了一下

#include<stdio.h>
int count(int n);
void print(int n);
void out(int n);
int main(void)
{
	char s[100];
	char *print[10] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};/*用指针数组,没用二维数组,显得我是学过指针的【狗头】*/
	int digit,sum,i,a[10];
	i=sum=0;
	
	while((s[i]=getchar())!='\n')
		i++;
	s[i]='\0';	
	
	
	for(i=0;s[i]!='\0';i++)
		sum+=s[i]-'0';
	
	if(sum>99)
	{
		printf("%s ",print[sum/100]);//135,刚好百位1对应数组的第1列;下面同理
		printf("%s ",print[(sum%100)/10]);
		printf("%s",print[sum%10]);
	}
	else if(sum>9)
	{
		printf("%s ",print[sum/10]);
		printf("%s",print[sum%10]);
	}
	else
	{
		printf("%s",print[sum]);
	}
	
	return 0;
}

总结:数组真是个好东西

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值