菜鸟记录:c语言实现PAT甲级1005–Spell It Right

 非常简单的一题了,但还是交了两三次,原因:对数组的理解不足;对数字和字符之间的转换不够敏感。这将在下文中细说。

Given a non-negative integer N, your task is to compute the sum of all the digits of N, and output every digit of the sum in English.

Input Specification:

Each input file contains one test case. Each case occupies one line which contains an N (10100).

Output Specification:

For each test case, output in one line the digits of the sum in English words. There must be one space between two consecutive words, but no extra space at the end of a line.

Sample Input:

12345
 

Sample Output:

one five

题目分析

  输入一串数字,然后用英文表达所有数字相加和的每一位数字。

    输入:10100以内的数字

    输出:和的每位数字英文表达(eg:sum=256,output=two five six)

首先很明显代码是不会翻译你的结果的,所有用一个数组来存储表示每位数字的英文,其次,10100的数字不需要精准表示,因为这里也就100个数字,不是10100个数字,开始我在这卡了半天,想着数字太大要精准存储,特地翻了之前写的c语言-大数阶乘 - 1001010 - 博客园 (cnblogs.com)一文,后面发现不大行的通,审视一遍后发现了问题,最后输出,要怎么拆开数字和也是个问题。

个人想法

  首先,还是从变量入手

1 #define  MAX  100
2 int N,m;//输入N,用于统计N的位数m
3 char lan[10][10] = { "zero","one","two","three","four","five","six","seven","eight","nine" };
4 int sum,a[MAX];//计算和sum,数组a用来记录拆开的sum
5 char n[MAX];

  这里开始是想N用来输入数据,后面发现循环过程中因为不知道它的位数,所以往往遍历要很多【补:而且N作为int变量放不了100位,double型的时候可以,但sum作为int不能让N强转,都作为double时就会很麻烦】,所以在错了一次后采取了  char n[MAX];  的写法,这样有很多的妙处:

  1. 可以利用字符串来进行自动分割,即在输入时不赋值在地址上(n的每位地址),scanf("%s", &n[i]); ❌  scanf("%s", &n);❌  scanf("%s", n);✔  c语言因为只接受字符,不支持string,写成这样就会自动把一串数字字符串分成单独的数字字符并赋值在每个空间单位上。
  2. 循环遍历时,不需要知道有几位,因为每个字符是被附在每个单位空间上的,所以这个数组遍历到空,即'\0'就可以停止。
  3. 由于得到的是字符的地址(数字自生的ACII值),所以在计算sum时,不用强转,而是减去0的ACII值,这个差不仅是地址差也非常融洽的是数字之间的差。

  到这里其实已经没有什么疑惑的点了,下面直接上完整代码。

 1 #include<stdio.h>
 2 
 3 #define  MAX  150
 4 int N,m;
 5 char n[MAX];
 6 char lan[10][10] = { "zero","one","two","three","four","five","six","seven","eight","nine" };
 7 int sum,a[MAX];
 8 int main() {
 9     scanf("%s", n);
10     for (int i = 0; n[i] != '\0'; i++) {
11         sum += n[i] - '0';
12     }
13     if (sum == 0){printf("zero");return 0;}//如果和等于0 ,那么直接输出“zero”就行。注意,这里必须return终止,因为数组a[-1]也是0
14     for (int i = 0; sum; i++) {
15         a[i] = sum % 10;
16         sum /= 10;
17         m += 1;//m记录sum的位数,但注意数组在使用时要减1,因为超范围了
18     }//sum最后等于0时即完成所有位数的记录,终止循环(非常巧妙) 
19     
20         printf("%s", lan[a[m - 1]]);
21         for(int i=m-2;i>=0;i--)
22             printf(" %s", lan[a[i]]);//老一套输出格式,每一位的数字对于英语组记录的每一位上的英文
23     
24     return 0;
25 }

菜鸟记录:c语言实现PAT甲级1005--Spell It Right

 

总结

  • 数组的利用,例如本文对英语的存储采用了二维数组,由于是char型,每单位只存放一个字符,所以lan[10][10]有10行10列,每列存放一个字符,一行存放10个字符。如果列数不足或是刚好,就会因为没有读到 '\0' 而出现连续输出,如下。每列只有5个单位,故原本“seven”就该停止却因为没有 '\0' 而读取到下一行“eight”一直到“nine”才停下。同样还有上文提到的数组地址。 菜鸟记录:c语言实现PAT甲级1005--Spell It Right
  •  字符与数字的转换。
  • 停止条件的巧妙使用,如这里for循环采用sum=0停止的条件,是我个人之前没看过的。

  

                                                                                                         

 

原文链接:https://www.cnblogs.com/whf10000010/p/17360701.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:菜鸟记录:c语言实现PAT甲级1005–Spell It Right - Python技术站

(0)
上一篇 2023年4月27日
下一篇 2023年4月28日

相关文章

  • ubuntu系统下C++调用matlab程序的方法详解

    关于在Ubuntu系统下C++调用matlab程序的方法详解,我整理了以下的攻略: 确认安装及配置 在开始调用matlab程序前,必须要确认系统已安装matlab软件及其C++编译器。同时,也需要设置matlab的环境变量来确保matlab程序能够被其他程序调用。 确认安装matlab 首先,可以在终端中输入以下命令,确认matlab是否已正确安装: mat…

    C 2023年5月23日
    00
  • C语言 实现输入任意多个整数

    要实现输入任意多个整数,可以使用C语言中的循环和数组来完成。以下是具体实现的步骤: 步骤一:定义变量和数组 首先要定义一个整型数组,用来存储输入的整数。同时还要定义一个变量来记录输入的整数个数,以此方便后续的循环。 int nums[100]; // 定义一个数组,用来存储输入的整数 int count = 0; // 定义一个变量,用来记录输入的整数个数 …

    C 2023年5月23日
    00
  • C++实现KFC点餐系统

    C++实现KFC点餐系统 介绍 KFC点餐系统是一个比较基础和实用的点餐系统,程序的主要功能是菜单的展示,菜品的选购和账单的结算,适合初学者学习C++的面向对象编程思想。 设计 系统主要结构通过类和对象来实现,主要包括管理类,订单类, 菜品类和顾客类,其中管理类为整个系统的核心,负责菜单的初始化和展示、订单管理以及结算等操作。 核心功能 1. 菜单初始化和展…

    C 2023年5月23日
    00
  • C C++中实参和参数的区别

    C/C++中实参和参数的区别 在C/C++中,函数的参数有两种:形式参数和实际参数。这篇文章将会讲解这两种参数的区别,以及它们在函数调用和定义中的使用方法。 形式参数和实际参数 形式参数 在函数定义时,参数列表中声明的参数被称为形式参数。它们在函数内部作为局部变量使用,函数被调用时,会将实际参数的值传递给形式参数,以便在函数内部使用。 函数定义时形式参数的语…

    C 2023年5月10日
    00
  • docker 文件存放路径, 修改端口映射操作方式

    下面给出 Docker 文件存放路径和修改端口映射操作方式的完整攻略。 Docker 文件存放路径 Docker 容器的数据和配置会存储在宿主机的某个目录中,称为 Docker 数据目录,也就是容器数据的本地持久化存储路径。 查看容器数据目录 可以通过以下指令查看容器数据目录: docker inspect <容器名称或ID> | grep -i…

    C 2023年5月23日
    00
  • C语言超详细讲解函数栈帧的创建和销毁

    C语言超详细讲解函数栈帧的创建和销毁 什么是函数栈帧? 函数栈帧也叫做栈帧,是存放函数局部变量、参数、函数返回地址等信息的一段内存空间。在函数被调用时,会动态地在栈上分配一段空间来存放函数栈帧,当函数执行完毕后释放这段空间。 函数栈帧的创建过程 当函数被调用时,会通过以下步骤创建函数栈帧: 将函数调用后下一条指令(即函数体里的第一条语句)的地址压入栈中,这里…

    C 2023年5月23日
    00
  • C语言实现简易的三子棋小游戏

    C语言实现简易的三子棋小游戏 概述 本文将讲解如何使用C语言编写一个简易的三子棋小游戏,涉及到的编程知识包括二维数组、循环结构、条件语句等基本概念。 实现步骤 1. 创建游戏棋盘 我们可以使用一个三行三列的二维数组来表示游戏的棋盘,初始化的时候将数组元素全部赋值为空格即可。 示例代码: char board[3][3] = { {‘ ‘, ‘ ‘, ‘ ‘}…

    C 2023年5月23日
    00
  • C语言模拟实现C++的继承与多态示例

    下面我将为您详细讲解如何用C语言模拟实现C++的继承与多态。 1. C语言模拟实现C++的继承 C语言中没有类的概念,但是我们可以使用结构体和指针来模拟类的实现,从而实现继承的功能。 1.1 结构体实现继承 我们可以通过在子结构体中嵌入父结构体来实现继承的功能。下面是一个示例代码: #include <stdio.h> // 父类 struct …

    C 2023年5月23日
    00
合作推广
合作推广
分享本页
返回顶部