[LeetCode-0009题-回文数] | 刷题打卡

122 阅读1分钟

掘金团队号上线,助你 Offer 临门! 点击 查看详情

一、题目描述

给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。

回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。例如,121 是回文,而 123 不是。

eg1:
输入:x = 121
输出:true

eg2:
输入:x = -121
输出:false
解释:从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。

eg3:
输入:x = 10
输出:false
解释:从右向左读, 为 01 。因此它不是一个回文数。

eg4:
输入:x = -101
输出:false

二、思路分析

看到测试用例,还是想到区分一下负数和非负数
  1. 负数的话,直接返回false
    
  2. 非负数的话,转换成字符串再reverse
    

三、解题代码

/**
 * @param {number} x
 * @return {boolean}
 */
var isPalindrome = function(x) {
    if (x < 0) return false
    const reverseString = x.toString().split('').reverse().join('')
    return +reverseString === x
};

四、总结

  • 本题细心一点就好。
  • 每天一练,持续学习