Golang | Leetcode Golang题解之第397题整数替换

题目:

题解:

Go 复制代码
func integerReplacement(n int) (ans int) {
    for n != 1 {
        switch {
        case n%2 == 0:
            ans++
            n /= 2
        case n%4 == 1:
            ans += 2
            n /= 2
        case n == 3:
            ans += 2
            n = 1
        default:
            ans += 2
            n = n/2 + 1
        }
    }
    return
}
相关推荐
老姚---老姚7 小时前
在windows下编译go语言编写的dll库
开发语言·windows·golang
VT.馒头9 小时前
【力扣】2625. 扁平化嵌套数组
前端·javascript·算法·leetcode·职场和发展·typescript
毅炼10 小时前
hot100打卡——day17
java·数据结构·算法·leetcode·深度优先
Tisfy10 小时前
LeetCode 3010.将数组分成最小总代价的子数组 I:排序 OR 维护最小次小
算法·leetcode·题解·排序·最小次小值
草履虫建模12 小时前
力扣算法 121. 买卖股票的最佳时机
算法·leetcode·职场和发展·贪心算法·动态规划·一次遍历
爱尔兰极光12 小时前
LeetCode--有序数组的平方
算法·leetcode·职场和发展
haluhalu.12 小时前
LeetCode---基础算法刷题指南
数据结构·算法·leetcode
iAkuya12 小时前
(leetcode)力扣100 58组合总和(回溯)
算法·leetcode·职场和发展
bing.shao12 小时前
Golang 开发者视角:解读《“人工智能 + 制造” 专项行动》的技术落地机遇
人工智能·golang·制造
ONE_PUNCH_Ge12 小时前
Go 语言泛型
开发语言·后端·golang