数字的处理与判断

题目描述

给出一个不多于5位的整数,要求 1、求出它是几位数 2、分别输出每一位数字 3、按逆序输出各位数字,例如原数为321,应输出123

输入

一个不大于5位的数字

输出

三行 第一行 位数 第二行 用空格分开的每个数字,注意最后一个数字后没有空格 第三行 按逆序输出这个数

样例输入

12345

样例输出

5
1 2 3 4 5
54321

解析

  • 先定义一个数组用来存放每一位数字,再定义一个 n 作为输入的数,接着定义一个 number 来记录是几位数。
  • 定义一个 for 循环,n % 10 的值赋给 num[],这样就可以获取得最后一个数;n = n / 10 向前进位,n 是没有小数位的。此时 num[] 这个数组里面的数字和输入的顺序是相反的。
  • 再定义一个 for 循环,倒过来输出 num[],记住用空格分开的每个数字,注意最后一个数字后没有空格。
  • 最后按照 num[]的顺序输出,也就是逆序输出。

参考代码

#include<iostream>
using namespace std;
int main()
{
    int num[5];  //定义一个有 5 个元素的数组
    int n;
    int number = 0; //记录数位
    cin >> n;  //获取输入的数
    for (int i = 0; i < 5; i++) {  //
        if (n == 0) break;  //如果输入的数为 0 则退出这个循环
        else {
            num[i] = n % 10;  //获取最后一位数,num[0] 为最后一个数,num[1] 是倒数第二个数
            n = n / 10;  //n 向前进 1 位,无小数点
            number++;
        }
    }
    cout << number << endl;  //输出数位
    for (int i = number - 1; i >= 0; i--) {
        if (i != 0) {  //如果 num[i] 不是最后一个数,则加一个空格
            cout << num[i] << " ";
        }
        else cout << num[i];  //输出最后一个数
    }
    cout << endl;  //换行
    for (int i = 0; i < number; i++) {
        cout << num[i];  //按照 num[i] 顺序输出
    }
    return 0;
}

运行结果

  • 若有问题,请评论出来,谢谢!
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容