📑 题目:9. 回文数

🚀 本题 LeetCode 传送门

题目大意

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

解题思路

  • 判断一个整数是不是回文数。
  • 简单题。注意会有负数的情况,负数,个位数,10 都不是回文数。其他的整数再按照回文的规则判断。

代码

  1. package leetcode
  2. import ""strconv""
  3. // 解法一
  4. func isPalindrome(x int) bool {
  5. if x < 0 {
  6. return false
  7. }
  8. if x == 0 {
  9. return true
  10. }
  11. if x%10 == 0 {
  12. return false
  13. }
  14. arr := make([]int, 0, 32)
  15. for x > 0 {
  16. arr = append(arr, x%10)
  17. x = x / 10
  18. }
  19. sz := len(arr)
  20. for i, j := 0, sz-1; i <= j; i, j = i+1, j-1 {
  21. if arr[i] != arr[j] {
  22. return false
  23. }
  24. }
  25. return true
  26. }
  27. // 解法二 数字转字符串
  28. func isPalindrome1(x int) bool {
  29. if x < 0 {
  30. return false
  31. }
  32. if x < 10 {
  33. return true
  34. }
  35. s := strconv.Itoa(x)
  36. length := len(s)
  37. for i := 0; i <= length/2; i++ {
  38. if s[i] != s[length-1-i] {
  39. return false
  40. }
  41. }
  42. return true
  43. }