题解 | #回文对称数#

回文对称数

https://ac.nowcoder.com/acm/problem/22169

我觉得对于初学者来说难点在于如何把数字一位位地取出来。

一种比较通用的方法是将它对10取模,然后除以十(相当于舍去个位,原来的十位成为新的个位,以此类推)。

由于不清楚数字的位数,使用 while 循环的同时利用 C++ 非 00 即为真的特性判断是否取完即可。

使用取出来的低位作为高位构造一个新数,如果与旧数相同说明旧数是回文数

需要特判的是 i<10i<10 的情况

#include<stdio.h>
int n;
int main(){
    scanf("%d",&n);
    for(int i=1;i<=n;i++){
        int t=i,a=0;
        while(t){
            a*=10;
            a+=t%10;
            t/=10;
        }
        if(a==i||i<10) printf("%d\n",i);
    }
}
题解 文章被收录于专栏

https://ayx.moefox.tech/

全部评论

相关推荐

10-11 17:45
门头沟学院 Java
走吗:别怕 我以前也是这么认为 虽然一面就挂 但是颇有收获!
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务