Golang | Leetcode Golang题解之第556题下一个更大元素III

题目:

题解:

Go 复制代码
func nextGreaterElement(n int) int {
    x, cnt := n, 1
    for ; x >= 10 && x/10%10 >= x%10; x /= 10 {
        cnt++
    }
    x /= 10
    if x == 0 {
        return -1
    }

    targetDigit := x % 10
    x2, cnt2 := n, 0
    for ; x2%10 <= targetDigit; x2 /= 10 {
        cnt2++
    }
    x += x2%10 - targetDigit // 把 x2%10 换到 targetDigit 上

    for i := 0; i < cnt; i++ { // 反转 n 末尾的 cnt 个数字拼到 x 后
        d := targetDigit
        if i != cnt2 {
            d = n % 10
        }
        if x > math.MaxInt32/10 || x == math.MaxInt32/10 && d > 7 {
            return -1
        }
        x = x*10 + d
        n /= 10
    }
    return x
}
相关推荐
Swift社区12 小时前
LeetCode 383 赎金信
算法·leetcode·职场和发展
鱼跃鹰飞12 小时前
LeetCode热题100:5.最长回文子串
数据结构·算法·leetcode
季明洵12 小时前
力扣反转链表、两两交换链表中的节点、删除链表的倒数第N个节点
java·算法·leetcode·链表
YuTaoShao16 小时前
【LeetCode 每日一题】面试题 17.12. BiNode
算法·leetcode·深度优先
夏鹏今天学习了吗18 小时前
【LeetCode热题100(95/100)】寻找重复数
算法·leetcode·职场和发展
圣保罗的大教堂1 天前
leetcode 3315. 构造最小位运算数组 II 中等
leetcode
Anastasiozzzz1 天前
leetcode力扣hot100困难题--4.俩个正序数列的中位数
java·算法·leetcode·面试·职场和发展
Tisfy1 天前
LeetCode 3510.移除最小数对使数组有序 II:有序集合
算法·leetcode·题解·设计·有序集合
TracyCoder1231 天前
LeetCode Hot100(1/100)——1. 两数之和 (Two Sum)
算法·leetcode