数字的处理与判断

题目:给出一个不多于5位的整数

要求1.求出它是几位数

      2.分别输出每一位数字(用空格分开每个  数字,最后一个数字没有空格)

      3.按逆序输出各位数字

样例输入:12345

样例输入:5

              1 2 3 4 5

              54321

分析:题目说给出一个不多于5位的整数(n),我们可以申请5个整型的数组,求它是几位数,我们可以利用取余取整,求出每位数字是什么并放在数组空间中,并用number求出数字的个数,把求出的每个数字按顺序输出,并按逆序输出。注意(n=0)的情况。

取余取整:num[i] = n % 10; 求出最后一位数

              n = n / 10; 小数点前移一位

              number++;计数

格式输出:if (i != 0)

               cout << num[i] << " ";                     

如果 num[i] 不是最后一个数,则加一个空格

   题解:

#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;

}

  • 10
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值