赞
踩
import "strconv"
func monotoneIncreasingDigits(n int) int {
str := strconv.Itoa(n)
nums := []byte(str)
length := len(nums)
if length <= 1 {
return n
}
for i := length - 1; i > 0; i-- {
//如果前一个数字比当前值大,说明不是单调递增的,把前一个数字减1,之后所有数字变成9
if nums[i-1] > nums[i] {
nums[i-1]--
for j := i; j < length; j++ {
nums[j] = '9'
}
}
}
res, _ := strconv.Atoi(string(nums))
return res
}
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。