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' 转换为数字,然后通过索引查找对应的拼音。

全部评论

相关推荐

2024-12-19 19:09
已编辑
南京信息工程大学 Java
查看27道真题和解析
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务