1.代码:
#include<stdio.h>
int main (void)
{
int n, value, value1, value2, sum=0, x, value3, qian=1000, y=0, jishuqi=0;
scanf("%d", &n);
value=n/100000000;
if(value!=0){
printf("%cY", 'a'+value); /*输出亿位*/
}
value1=n%100000000;
value2=value1/10000; /*得到万位数字*/
while(qian!=0){ /*输出万位*/
if(value2==0){
break;
}
x=value2/qian;
value2=value2%qian;
qian=qian/10;
y++;
if(value==0&&x==0){
if(jishuqi!=1){
continue;
}
}
if(x==0){
sum++;
if(sum<=1) {
if(y!=4){
printf("%c", 'a');
}
}
}
if(x!=0){
sum=0;
jishuqi=1;
printf("%c", 'a'+x);
switch(y){
case 1: printf("Q"); break;
case 2: printf("B"); break;
case 3: printf("S"); break;
}
}
}
if(y!=0){
printf("W"); /*输出万位结束*/
}
sum=0; /*输出千位以下需要重新赋初始值,因为在万位运算的时候值变化了*/
qian=1000;
y=0;
jishuqi=0;
value3=n%10000; /*得到千以及以下数字*/
while(qian!=0){
x=value3/qian;
value3=value3%qian;
qian=qian/10;
y++;
if((n%100000000)/10000==0&&x==0){
if(jishuqi!=1){
continue;
}
}
if(value3!=0){
if(x==0){
sum++;
if(sum<=1) {
printf("%c", 'a');
}
}
}
if(x!=0){
sum=0;
jishuqi=1;
printf("%c", 'a'+x);
switch(y){
case 1: printf("Q"); break;
case 2: printf("B"); break;
case 3: printf("S"); break;
}
}
}
if(n==0){
printf("%c", 'a');
}
}
2.
设计思路
第一步:整体来看,把他们区分为三个区间,分别是亿,万,千以下
第二步:输出亿位,这个很简单
第三部:输出万位,这个考虑的就有很多,比如首位是零,还有连续的零,最后一个是零,下面一一讲解
********:第一:比如亿位为零且万位第一位位为零,那么这个零不能输出
********:第二:万位中间有两个零,但按我们中文规则只能输出一个零,且没有“零百”,“零十”,而且最后一位为零不输出
********:有数字的输出千,百,十位
********:下面这个用来判断是否有万位上的数字
第四步:输出千以下位,大概同万位运算方法一样
思维结构图: