您的位置:首页 > 其它

每日一题:Leetcode 9.回文数

2020-03-08 14:08 381 查看

题目描述

判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。

示例 1:

输入: 121
输出: true

示例 2:

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

示例 3:

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

题解

题目难度:简单

解题思路:本题目可以通过把输入数据转换为字符串形式解决,也可以对整型数据是否回文直接进行判断。我们可以通过判断输入数据翻转后的值是否与原值相同来判断其回文与否(整数翻转的方法可见我的博客每日一题:Leetcode 7.整数翻转)。值得注意的是,如果数据为负值或溢出,则其一定不回文。

AC代码

package main

import "fmt"

const MAX_VALUE = 2147483647

func main(){
var x int
fmt.Scanf("%d", &x)
fmt.Print( isPalindrome( x ) )
}

//本函数用于判断参数x是否为回文数
func isPalindrome(x int) bool {
if x<0 || x>MAX_VALUE {
return false  //如果x为负数或正值溢出,则其一定为非回文数
}
x0 := x  //x0用于储存x的原值
var res  = 0
for ; x>0 ; x/=10 {
res = res*10 + x%10
}

if x0==res {
return true  //如果输入数据x翻转后的值res与原值x0相等,则其为回文数
}
return false
}

原题目链接:https://leetcode-cn.com/problems/palindrome-number

  • 点赞
  • 收藏
  • 分享
  • 文章举报
在风暴的中央 发布了28 篇原创文章 · 获赞 4 · 访问量 3586 私信 关注
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: