判断回文数

题目:

 

 

解法一:将整数转换为字符串

python3:

class Solution:
    def isPalindrome(self, x: int) -> bool:
        return str(x)==str(x)[::-1]

解法二:只需要判断一半

C语言

reversed == x 成立则一定是偶数位,reversed / 10 == x 成立则一定是奇数位,以及包含了奇偶的分支判断了。

class Solution {
    public boolean isPalindrome(int x) {
        // 0 是回文数
        if (x == 0) return true; 
        // 负数和除 0 以外以 0 结尾的数都不是回文数
        if (x < 0 || x % 10 == 0) return false; 
        // 记录 x 后一半的翻转,如 x = 4334,reversed = 43;x = 54345,reversed = 54
        int reversed = 0; 
        while (x > reversed) {
            reversed = reversed * 10 + x % 10;
            x /= 10;
        }
// x有偶数位和奇数位两种情况
        return reversed == x || reversed / 10 == x;
    }
} 

解法三:将数据完全翻转与原数据对比

public class Solution {
    public bool IsPalindrome(int x) {
        if(x<0) return false;
        if(x==0) return true;
        int a=x;
        int sum=0;
        while(x!=0){
            sum=sum*10+x%10;
            x/=10;
        }
        return sum==a;
    }
}

 

posted @ 2023-01-21 00:08  JINGSOLO  阅读(49)  评论(0编辑  收藏  举报