输入一个整形数(最多可以到亿位),然后按汉语的习惯,将其读出来并输出。如1052,读作:一千零五十二。 程序运行示例: 1052 一千零五十二

简介: 输入一个整形数(最多可以到亿位),然后按汉语的习惯,将其读出来并输出。如1052,读作:一千零五十二。 程序运行示例: 1052 一千零五十二

输入一个整形数(最多可以到亿位),然后按汉语的习惯,将其读出来并输出。如1052,读作:一千零五十二。


程序运行示例:

1052

一千零五十二

999999999

九亿九千九百九十九万九千九百九十九


可能会有一些边界条件没有考虑到

最大到九亿九千九百九十九万九千九百九十九

下面是代码,解析写在注释里了


#include <stdio.h>
#include <string.h>
#include <stdlib.h>
const char shuzi[10][4] = {"零", "一", "二", "三", "四", "五", "六", "七", "八", "九"};
const char weishu[5][4] = {"十", "百", "千", "万", "亿"};
//储存中文数字
void read(char *str);
int count=0,len;
int main()
{
    char str[11] = {'0'};//初始化字符串
    scanf("%s", str + 1);
    len=strlen(str);
    read(str + 1);
    return 0;
}
void read(char *str)
{
    if (strlen(str) == 0)
    {
        return;
    }
    else
    {
        switch (str[0])//分别判断每一位的读法
        {
        case '0':
            if (str[1] != '0' && strlen(str) >= 2)
                printf("%s", shuzi[0]);
                //0的情况比较特殊,多个0位只读一遍
            break;
        case '1':
            if (strlen(str) != 2 && strlen(str) != 6)
                printf("%s", shuzi[1]);
            else if (*(str - 1) != '0')
                printf("%s", shuzi[1]);
            break;
        case '2':
            printf("%s", shuzi[2]);
            break;
        case '3':
            printf("%s", shuzi[3]);
            break;
        case '4':
            printf("%s", shuzi[4]);
            break;
        case '5':
            printf("%s", shuzi[5]);
            break;
        case '6':
            printf("%s", shuzi[6]);
            break;
        case '7':
            printf("%s", shuzi[7]);
            break;
        case '8':
            printf("%s", shuzi[8]);
            break;
        case '9':
            printf("%s", shuzi[9]);
            break;
        default:
            return;
        }
        switch (strlen(str))
        {
        case 9:
            printf("%s", weishu[4]);
            break;
        case 8:
            if (str[0] != '0')
                printf("%s", weishu[2]);
            break;
        case 7:
            if (str[0] != '0')
                printf("%s", weishu[1]);
            break;
        case 6:
            if (str[0] != '0')
                printf("%s", weishu[0]);
            break;
        case 5:
            break;
        case 4:
            if (str[0] != '0')
                printf("%s", weishu[2]);
            break;
        case 3:
            if (str[0] != '0')
                printf("%s", weishu[1]);
            break;
        case 2:
            if (str[0] != '0')
                printf("%s", weishu[0]);
            break;
        case 1:
            break;
        default:
            return;
        }
        count++;
        if((len-count==5)&&(len>4))
            printf("%s", weishu[3]);
        read(++str);//继续判断下一位
    }
}
相关文章
|
5月前
|
机器学习/深度学习 编译器 C语言
【C语言】数据输出的域宽控制(如何在输出数据时控制0占位)(如何输出前导0)(保留几位小数)(乘法口诀表打印不齐)等问题
【C语言】数据输出的域宽控制(如何在输出数据时控制0占位)(如何输出前导0)(保留几位小数)(乘法口诀表打印不齐)等问题
73 0
|
2月前
|
弹性计算 安全 关系型数据库
用100字写一个阿里云应用的例子
用户张三利用阿里云的ECS部署了他的在线电商网站,并结合RDS存储商品与用户信息,OSS存放产品图片及宣传资料,通过CDN提升全球访问速度,SLB确保网站高可用性,云盾保障整体安全,构建了一个稳定、高效且安全的在线购物平台。
|
2月前
|
人工智能 Java 容器
十个Java字符串操作示例程序
十个Java字符串操作示例程序
18 1
|
程序员 Serverless Python
【Python】综合运用知识点,判断输入数字是否为素数以及计算等级差,并将值保存到txt文本文档里
最近在学习python,如何快速提高所学编程和加深印象呢 很显然,通过多练习和尝试编写代码实现功能
127 0
|
C语言
C语言格式输入与输出深度剖析
C语言格式输入与输出深度剖析
316 0
C语言格式输入与输出深度剖析
|
缓存 移动开发 编译器
C++STL开发温习与总结(六): 6.C++语言输入/输出流定义之输入/输出格式控制
C++STL开发温习与总结(六): 6.C++语言输入/输出流定义之输入/输出格式控制
C++STL开发温习与总结(六): 6.C++语言输入/输出流定义之输入/输出格式控制
|
C语言
C语言上机实验:输入一个字符和一个3位数字并作判断
C语言上机实验:输入一个字符和一个3位数字并作判断
173 0
|
Python
Python自写函数内容实现十进制数转化为二、八、十六进制数
Python自写函数内容实现十进制数转化为二、八、十六进制数
314 0