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

题目:

题解:

java 复制代码
class Solution {
    public int integerReplacement(int n) {
        int ans = 0;
        while (n != 1) {
            if (n % 2 == 0) {
                ++ans;
                n /= 2;
            } else if (n % 4 == 1) {
                ans += 2;
                n /= 2;
            } else {
                if (n == 3) {
                    ans += 2;
                    n = 1;
                } else {
                    ans += 2;
                    n = n / 2 + 1;
                }
            }
        }
        return ans;
    }
}
相关推荐
Elieal11 分钟前
5 种方式快速创建 SpringBoot 项目
java·spring boot·后端
better_liang19 分钟前
每日Java面试场景题知识点之-Java修饰符
java·访问控制·static·abstract·final·修饰符·企业级开发
努力学算法的蒟蒻23 分钟前
day58(1.9)——leetcode面试经典150
算法·leetcode·面试
rgeshfgreh34 分钟前
Spring事务传播机制深度解析
java·前端·数据库
无名-CODING35 分钟前
Java Spring 事务管理深度指南
java·数据库·spring
xiaolyuh12335 分钟前
Spring MVC Bean 参数校验 @Validated
java·spring·mvc
蕨蕨学AI42 分钟前
【Wolfram语言】45.2 真实数据集
java·数据库
im_AMBER1 小时前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
予枫的编程笔记1 小时前
【Java集合】深入浅出 Java HashMap:从链表到红黑树的“进化”之路
java·开发语言·数据结构·人工智能·链表·哈希算法
ohoy1 小时前
RedisTemplate 使用之Set
java·开发语言·redis