回文数

Go 回文数

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

  • 判断一个整数是不是回文数。
  • 注意会有负数的情况,负数,个位数,10 都不是回文数。其他的整数再按照回文的规则判断。
    
    import "strconv"
    
    // 解法一
    func isPalindrome(x int) bool {
    	if x < 0 {
    		return false
    	}
    	if x == 0 {
    		return true
    	}
    	if x%10 == 0 {
    		return false
    	}
    	arr := make([]int, 0, 32)
    	for x > 0 {
    		arr = append(arr, x%10)
    		x = x / 10
    	}
    	sz := len(arr)
    	for i, j := 0, sz-1; i <= j; i, j = i+1, j-1 {
    		if arr[i] != arr[j] {
    			return false
    		}
    	}
    	return true
    }
    
    // 解法二 数字转字符串
    func isPalindrome1(x int) bool {
    	if x < 0 {
    		return false
    	}
    	if x < 10 {
    		return true
    	}
    	s := strconv.Itoa(x)
    	length := len(s)
    	for i := 0; i <= length/2; i++ {
    		if s[i] != s[length-1-i] {
    			return false
    		}
    	}
    	return true
    }




留言簿


119.123.77.243

4个月前

一直想学算法 都没时间

回复

(c) 2024 OYYM - 赣ICP备17008861号-1

欧阳裕民个人博客