文档章节

判断是否为回文数 Palindrome Number

叶枫啦啦
 叶枫啦啦
发布于 2017/06/27 15:00
字数 480
阅读 1
收藏 0

问题:

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

click to show spoilers.

Some hints:

Could negative integers be palindromes? (ie, -1)

If you are thinking of converting the integer to string, note the restriction of using extra space.

You could also try reversing an integer. However, if you have solved the problem "Reverse Integer", you know that the reversed integer might overflow. How would you handle such case?

There is a more generic way of solving this problem.

【注】问题要求O(1)空间复杂度,负数不是回文数

解决:

①每次提取头部和尾部的两个数,判断它们是否相等,判断后去掉头尾继续。采用除数和取余实现。暂时不能查看提交信息!耗时337ms。

public class Solution {
    public boolean isPalindrome(int x) {
        if(x < 0) return false;
        int len = 1;
        while(x / len >=10) len *= 10;
        while(x > 0){
            int head = x / len;//获取头部
            int tail = x % 10;//获取尾部

            if (head != tail) {
                return false;
            }else{//去掉头部和尾部
                x = (x % len) / 10;
                len /= 100;

            }
        }
        return true;
    }
}

进化版:

public class Solution { //206ms
    public boolean isPalindrome(int x) {
        if(x < 0) return false;
        int div = 1;
        while(x / div >= 10) div = div * 10;  //位数
        while(x > 0) {
            if(x / div != x % 10) return false;
            x = x % div;  //去除头部
            x = x / 10;  //去除尾部
            div = div / 100;  //位数减2位
        }
        return true;
    }
}

③ 用tempx保存数字x的头部,用reverse保存除头部之外x位数的翻转,对比整个x的头尾两位,以及中间所有位reverse以后是否与不reverse时一致,即可得到结果。

public class Solution { //207ms
    public boolean isPalindrome(int x) {
        if (x < 0) {
            return false;
        }
        int tempX = x;
        int reverse = 0;        
        while (tempX >= 10) { //// 当tempX剩下一位数的时候停下来
            reverse = reverse * 10 + tempX % 10; //将除了最高位之外的位数翻转
            tempX /= 10; //取得最高位
        }    
   
        return tempX == x % 10 && reverse == x / 10; ////对比整个x的头尾两位,以及中间所有位reverse以后是否与不reverse时一致
    }
}

© 著作权归作者所有

共有 人打赏支持
叶枫啦啦
粉丝 10
博文 566
码字总数 343870
作品 0
海淀
LeetCode:Palindrome Number - 回文数

1、题目名称 Palindrome Number(回文数) 2、题目地址 https://leetcode.com/problems/palindrome-number 3、题目内容 英文:Determine whether an integer is a palindrome. Do this witho......

北风其凉
2015/09/24
109
0
LeetCode 9. Number(回文数)

原题: IDetermine whether an integer is a palindrome. An integer is a palindrome when it reads the same backward as forward. 判断一个整数是否是回文数。回文数是指正序(从左向右)......

dby_freedom
09/04
0
0
由两个n位数相乘得到的最大回文 Largest Palindrome Product

问题: Find the largest palindrome made from the product of two n-digit numbers. Since the result could be very large, you should return the largest palindrome mod 1337. Example......

叶枫啦啦
01/06
0
0
LeetCode:Valid Palindrome - 回文字符串

1、题目名称 Valid Palindrome(回文字符串) 2、题目地址 https://leetcode.com/problems/valid-palindrome/ 3、题目内容 英文:Given a string, determine if it is a palindrome, consid......

北风其凉
2015/08/05
0
0
[LeetCode] Shortest Palindrome 最短回文串

Given a string S, you are allowed to convert it to a palindrome by adding characters in front of it. Find and return the shortest palindrome you can find by performing this tran......

机器的心脏
2017/12/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

mysql 数据类型及占用字节数

数字类型 TINYINT                           1 字节 SMALLINT                          2 个字节 MEDIUMINT                         3 个字节...

会游泳的鱼_
43分钟前
3
0
高性能mysql:创建高性能的索引

性能优化简介 MySQL性能定义为完成某件任务所需要的时间量度,换句话说,性能即响应时间,这是一个非常重要的原则。我们通过任务和时间而不是资源来测量性能。数据库服务器的目的是执行SQL语...

背后的辛酸
58分钟前
4
0
HTTP get、post 中请求json与map传参格式

import java.io.IOException;import java.net.URI;import java.net.URISyntaxException;import java.nio.charset.Charset;import java.util.ArrayList;import java.util.List;im......

寒风中的独狼
今天
3
0
IDEA中tomcat启动慢 耗时10分钟

用idea中的tomcat以debug模式启动,会非常的慢,而正常启动没啥问题;原因是debug模式中View Breakpoints断点代码,断点的是jar包,而现在启动由于jar包发生变化,导致启动时一直处于等待中。...

GoodMarver
今天
5
0
Linux学习-10月18(awk)

9.6/9.7 awk 一、awk简介   1. awk是一种编程语言,用于对文本和数据进行处理的   2. 具有强大的文本格式化能力   3. 利用命令awk,可以将一些文本整理成为我们想要的样子   4. 命令awk...

wxy丶
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部