在一根无限长的数轴上,你站在0的位置。终点在target的位置。
你可以做一些数量的移动 numMoves :
每次你可以选择向左或向右移动。
第 i 次移动(从 i == 1 开始,到 i == numMoves ),在选择的方向上走 i 步。
给定整数 target ,返回 到达目标所需的 最小 移动次数(即最小 numMoves ) 。
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/reach-a-number
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
import math
class Solution:
def reachNumber(self, target: int) -> int:
target = abs(target)
t = math.ceil(math.sqrt(2*target + 0.25) - 0.5)
cs = (t + 1) * t // 2
delta = cs - target
return t if delta % 2 == 0 else t + (t & 1) + 1