题名:逆序的三位数
题目:程序每次读入一个正3位数,然后输出按位逆序的数字。注意:当输入的数字含有结尾的0时,输出不应带有前导的0。比如输入700,输出应该是7。
输入格式:每个测试是一个3位的正整数。
输出格式:输出按位逆序的数。
这道题乍一看很简单,就是三个变量的事,但运行结果成绩为0。正确做法是用/10和%10的方式求出个位、十位和百位。
c=n%10; temp1=n/10;
b=temp1%10; temp2=temp1/10;
a=temp2%10;
的形式获取一个数各个位上的数。
最难的是第3步,虽然代码给了,但还是需要搞明白它的原理:
a,b,c分别指百位,十位,个位。由于输入的数肯定是个位结尾,所以要先求个位(c)的值。获取c的值直接n%10就可以获取。而b就不能直接获取,而是先用n/10的方式扔掉c位保留b位,再用temp1%10的方式获取十位。百位也一样,temp2要在temp1的基础上扔掉b位保留a位,最后用temp2%10的方式获取百位。这样就可以获取一个数各个位上的数字。由于题目中明确指出n是三位数,所以用这种方法足矣了。
#include
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<
上面只是初学者的代码。编译时间长、占用空间大、不好看。其中temp1,temp2,if等都可以去掉。
代码如下:
#include
using namespace std;
int main(){
int n;
cin>>n;
int a=n%10;
int b=n/10%10;
int c=n/100;
cout<
这种代码看起来才美观呀