397. Integer Replacement
Given a positive integer n, you can apply one of the following operations:
- If
nis even, replacenwithn / 2. - If
nis odd, replacenwith eithern + 1orn - 1.
Return the minimum number of operations needed forn to become 1.
Example 1:
Input: n = 8
Output: 3
Explanation: 8 -> 4 -> 2 -> 1Example 2:
Input: n = 7
Output: 4
Explanation: 7 -> 8 -> 4 -> 2 -> 1
or 7 -> 6 -> 3 -> 2 -> 1Example 3:
Input: n = 4
Output: 2Constraints:
1 <= n <= 231 - 1
# @lc code=start
using LeetCode
function integer_replacement(n::Int)
res = 0
while n != 1
if iseven(n)
n >>= 1
else
n += (n & 2 == 0 || n == 3) ? -1 : 1
end
res += 1
end
return res
end
# @lc code=endinteger_replacement (generic function with 1 method)
This page was generated using DemoCards.jl and Literate.jl.