PTA - 1002 写出这个数 (20分)

1002 写出这个数 (20分)

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

输入格式:

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

输出格式:

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

输入样例:

1234567890987654321123456789

输出样式:

yi san wu

题目分析:

1.将每位数相加,再将sum的数字念出来。
2.能力有限,写的太麻烦了,有更好的、更简洁的代码欢迎评论。

代码如下:

#include <stdio.h>

#include <math.h>

int number( char *n );

void put_number( int n );

int main (void){
	char n[100];
	int i = 0;
	while((n[i] = getchar()) != '\n'){
		i++;
	}
	n[i] = '\0';
	//printf("%s\n", n);
	//number(n);
	put_number(number(n));
	return 0;
}

int number( char *n ){
	int sum = 0;
	while(*n != '\0'){
		switch(*n){
			case '0': sum = sum + 0;break;
			case '1': sum = sum + 1;break;
			case '2': sum = sum + 2;break;
			case '3': sum = sum + 3;break;
			case '4': sum = sum + 4;break;
			case '5': sum = sum + 5;break;
			case '6': sum = sum + 6;break;
			case '7': sum = sum + 7;break;
			case '8': sum = sum + 8;break;
			case '9': sum = sum + 9;break;
		}
		n++;
	}
	//printf("%d\n", sum);
	return  sum;
}

void put_number( int n ){
	int i, m = 0, number;
	number = n;
	while(number != 0){
		number /= 10;
		m++;
	}
	//printf("%d\n", m);
	number = n;
	while(m != 0){
		i = n / pow(10, m - 1);
		n = n - pow(10, m - 1) * i;
		//printf("%d %d\n", i, n);
		switch(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(n != 0){
			printf(" ");
		}else if(m != 1 && n == 0){
			printf(" ");
		}
		m--;
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值