C++PTA题解(3)——逆序的三位数

题目信息

题名:逆序的三位数

题目:程序每次读入一个正3位数,然后输出按位逆序的数字。注意:当输入的数字含有结尾的0时,输出不应带有前导的0。比如输入700,输出应该是7。

输入格式:每个测试是一个3位的正整数。

输出格式:输出按位逆序的数。

分析题目

这道题乍一看很简单,就是三个变量的事,但运行结果成绩为0。正确做法是用/10和%10的方式求出个位、十位和百位。

  1. 先声明6个变量
  2. 输入n
  3. c=n%10; temp1=n/10;
    b=temp1%10; temp2=temp1/10;
    a=temp2%10;

    的形式获取一个数各个位上的数。

  4. 特判开头有没有0
  5. 如果有就只输出没有0的变量,如果没有就全部输出

最难的是第3步,虽然代码给了,但还是需要搞明白它的原理:

a,b,c分别指百位,十位,个位。由于输入的数肯定是个位结尾,所以要先求个位(c)的值。获取c的值直接n%10就可以获取。而b就不能直接获取,而是先用n/10的方式扔掉c位保留b位,再用temp1%10的方式获取十位。百位也一样,temp2要在temp1的基础上扔掉b位保留a位,最后用temp2%10的方式获取百位。这样就可以获取一个数各个位上的数字。由于题目中明确指出n是三位数,所以用这种方法足矣了。

示例代码

#include<bits/stdc++.h>
using namespace std;
int main(){
    int n,a,b,c,temp1,temp2;
    cin>>n;
    c=n%10; temp1=n/10;
    b=temp1%10; temp2=temp1/10;
    a=temp2%10;
    if(b==0 && c==0){
        cout<<a;
    }else if(c==0){
        cout<<b<<a;
    }else{
        cout<<c<<b<<a;
    }
    return 0;
}

上面只是初学者的代码。编译时间长、占用空间大、不好看。其中temp1,temp2,if等都可以去掉。

代码如下:

#include<bits/stdc++.h>
using namespace std;
int main(){
	int n;
	cin>>n;
	int a=n%10;
	int b=n/10%10;
	int c=n/100;
	cout<<a*100+b*10+c;
    return 0;
}

 这种代码看起来才美观呀

posted @ 2022-07-19 19:46  GitTJBKBeta  阅读(311)  评论(0编辑  收藏  举报