整数替换(力扣)HashMap + 递归 JAVA

给定一个正整数 n ,你可以做如下操作:

如果 n 是偶数,则用 n / 2替换 n 。 如果 n 是奇数,则可以用 n + 1或n - 1替换 n 。 返回 n 变为 1 所需的

最小替换次数 。

示例 1:

输入:n = 8

输出:3

解释:8 -> 4 -> 2 -> 1

示例 2:

输入:n = 7

输出:4

解释:7 -> 8 -> 4 -> 2 -> 1 或 7 -> 6 -> 3 -> 2 -> 1

示例 3:

输入:n = 4

输出:2

提示:

1 <= n <= 2^31 - 1

解题思路:

1、如果n 为偶数那就只有/2一种选项

2、如果n为奇数那么有 + 1和 - 1两种选择,这里用long因为2^31 - 1 + 1会爆掉int

3、利用HashMap存储值以免重复以空间换时间

代码:

java 复制代码
class Solution {
	Map<Long, Integer> map = new HashMap<>();
    public int integerReplacement(int n) {
          return dfs(n * 1L);
    }
    public int dfs(long n) {
    	if(n == 1) return 0;
    	if(map.containsKey(n)) return map.get(n);//先查看是否存储有
    	int ans = n % 2 == 0 ? dfs(n / 2) : Math.min(dfs(n + 1), dfs(n - 1));//开始存入
    	map.put(n, ++ ans);//记得是先变到n/2或n + 1 或 n - 1的状态所以需要 + 1
    	return ans;
    }
}
相关推荐
独断万古他化1 小时前
【抽奖系统开发实战】Spring Boot 抽奖模块全解析:MQ 异步处理、缓存信息、状态扭转与异常回滚
java·spring boot·redis·后端·缓存·rabbitmq·mvc
weisian1511 小时前
Java并发编程--12-读写锁与StampedLock:高并发读场景下的性能优化利器
java·开发语言·性能优化·读写锁·stampedlock
回到原点的码农9 小时前
Spring Data JDBC 详解
java·数据库·spring
gf13211119 小时前
python_查询并删除飞书多维表格中的记录
java·python·飞书
zb200641209 小时前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
一叶落4389 小时前
题目:15. 三数之和
c语言·数据结构·算法·leetcode
一勺菠萝丶9 小时前
Flowable + Spring 集成踩坑:流程结束监听器查询历史任务为空 & 获取不到审批意见
java·数据库·spring
jwn9999 小时前
Spring Boot 整合 Keycloak
java·spring boot·后端
宁波阿成9 小时前
OpenClaw 在 Ubuntu 22.04.5 LTS 上的安装与问题处理记录
java·linux·ubuntu·openclaw·龙虾
mldlds9 小时前
SpringBoot详解
java·spring boot·后端