Golang | Leetcode Golang题解之第390题消除游戏

题目:

题解:

Go 复制代码
func lastRemaining(n int) int {
    a1 := 1
    k, cnt, step := 0, n, 1
    for cnt > 1 {
        if k%2 == 0 { // 正向
            a1 += step
        } else { // 反向
            if cnt%2 == 1 {
                a1 += step
            }
        }
        k++
        cnt >>= 1
        step <<= 1
    }
    return a1
}
相关推荐
XFF不秃头2 小时前
力扣刷题笔记-旋转图像
c++·笔记·算法·leetcode
yaoh.wang5 小时前
力扣(LeetCode) 111: 二叉树的最小深度 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·深度优先
仲夏月二十八5 小时前
关于golang中何时使用值对象和指针对象的描述
开发语言·后端·golang
天远数科6 小时前
Go语言金融风控:天远 全能小微企业报告组合接口的 AES 加密与异构 JSON 解析
大数据·golang·json
wodet6 小时前
golang实现的批量审核文本服务
微服务·golang
努力学算法的蒟蒻7 小时前
day42(12.23)——leetcode面试经典150
算法·leetcode·面试
鹿角片ljp7 小时前
力扣226.翻转二叉树-递归
数据结构·算法·leetcode
iAkuya7 小时前
(leetcode)力扣100 21搜索二维矩阵2(z型搜索)
linux·leetcode·矩阵
(●—●)橘子……7 小时前
记力扣42.接雨水 练习理解
笔记·学习·算法·leetcode·职场和发展
朝花不迟暮7 小时前
go的文件操作
开发语言·后端·golang