L1-007念数字——字符串数组的应用

https://pintia.cn/problem-sets/994805046380707840/exam/problems/type/7?problemSetProblemId=994805136889593856&page=0

#include <stdio.h>
#include <string.h>

int main() {
    // 定义一个字符串数组,存储数字字符对应的拼音
    const char *digit_to_pinyin[] = {
        "ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"
    };
    
    char num[100];  // 创建一个字符数组来存储输入的整数,假设最多输入99个字符
    scanf("%s", num);  // 使用scanf读取输入的整数,作为字符串存储

    // 检查输入的第一个字符是否是负号
    if (num[0] == '-') {
        // 如果是负数,先输出 "fu"
        printf("fu ");
        // 从输入字符串的第二个字符开始,逐个处理数字部分
        for (int i = 1; i < strlen(num); i++) {
            // 使用num[i] - '0'将字符数字转换为整数,找到对应的拼音
            printf("%s", digit_to_pinyin[num[i] - '0']);
            
            // 如果当前数字不是最后一个数字,就输出空格
            if (i < strlen(num) - 1) {
                printf(" ");
            }
        }
    } else {
        // 如果是正数,则从第一个字符开始处理
        for (int i = 0; i < strlen(num); i++) {
            // 将每个数字字符转换为拼音并输出
            printf("%s", digit_to_pinyin[num[i] - '0']);
            
            // 如果当前数字不是最后一个数字,就输出空格
            if (i < strlen(num) - 1) {
                printf(" ");
            }
        }
    }

    return 0;  // 返回0表示程序执行完毕
}

const char *digit_to_pinyin[]:定义一个字符串数组,存储数字字符 09 对应的拼音。

digit_to_pinyin[num[i] - '0']:通过字符 num[i] 减去 '0' 转换为数字,然后通过索引查找对应的拼音。

全部评论

相关推荐

Twilight_m...:表格简历有点难绷。说说个人看法: 1.个人基本情况里好多无意义信息,什么婚姻状况、健康状况、兴趣爱好、户口所在地、身份证号码、邮政编码,不知道的以为你填什么申请表呢。 2.校内实践个人认为对找工作几乎没帮助,建议换成和测开有关的项目,实在没得写留着也行。 3.工作经历完全看不出来是干什么的,起码看着和计算机没啥关系,建议加强描述,写点你在工作期间的实际产出、解决了什么问题。 4.个人简述大而空,看着像AI生成,感觉问题最大。“Python,C,C++成为我打造高效稳定服务的得力工具”、“我渴望凭借自身技术知识与创新能力,推动人工智能技术的应用发展,助力社会实现智能化转型”有种小学作文的美感。而且你确定你个人简述里写的你都会嘛?你AI这块写的什么“深入研究”,发几篇顶会的硕博生都不一定敢这么写。而且你AI这块的能力和软测也完全无关啊。个人简述建议写你对哪些技术栈、哪些语言、哪些生产工具的掌握,写的有条理些,而且最好是和测开强相关的。
点赞 评论 收藏
分享
强大的马里奥:不太可能,我校计算机硕士就业率99%
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务