码迷,mamicode.com
首页 > 其他好文 > 详细

palindrome number

时间:2015-06-23 23:04:49      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:

1. Question

确定一个数是否是回文数。要求不使用额外空间。

Determine whether an integer is a palindrome. Do this without extra space.

 

2. Solution

如果是负数,就不是回文数。

2.1 reverse integer

采用反转整数的方法,注意处理溢出(采用long存储数据)

技术分享
public class Solution {
    public boolean isPalindrome(int x) {
        if( x < 0 )
            return false;
        long rev = 0;
        int y = x;
        while( y != 0 ){
            rev = rev * 10 + y % 10;
            y = y / 10;
        }
        if( rev == (long)x )
            return true;
        return false;
    }
}
View Code

2.2 整除取余计算

结合采用整除取余,同时从数的两端开始计算来判断(需要先确定位数)

技术分享
public class Solution {
    public boolean isPalindrome(int x) {
        if( x < 0 )
            return false;
        int bits = 1;
        for( int y=x/10; y!=0; y/=10,bits++ );
        for( int i=1; i<=bits/2; i++ ){
            if( ( ( x / (int)Math.pow( 10, bits-i ) ) % 10 )  != ( ( x / (int)Math.pow( 10, i-1 ) ) % 10 ) )
                return false;
        }
        return true;
    }
}
View Code

3. 复杂度

O(n)

 

palindrome number

标签:

原文地址:http://www.cnblogs.com/hf-cherish/p/4596321.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!