到达终点数字

从数轴上的0出发,每步走的长度与步数相同,求达到目标点所需的最少步数。本质是寻找1到n的和在部分数取负后等于目标值的解法。当sum-target为偶数时,一定能找到解决方案。通过累加正数并检查条件,可以找到最少步数。
摘要由CSDN通过智能技术生成

题目:

你从数轴上的0出发,可以选择向右或向左走,但是第n步只能走n步。问:走到target点所需的最少步数?

 

示例1:

target=2,最少步数为3

解释:向右走1步,向左走2步,向右走3步

 

示例2:

target=4,最少步数为3

解释:向左走1步,向右走2步,向右走3步

 

思路详解:

这道题的本质是 1+2+3+…+n,在一些数字前面取负号(代表向左走),使得这些数字的和等于target。

假设 sum=\sum_{i=1}^{n}i ,假设在第i个数前面取负号,那么得到的新的和为 sum-2i,变化肯定为偶数!

所以做法就是:一直累加1+2+3+……,直到sum>=target并且sum-target为偶数的时候,一共加了多少个数字,最少步数就为多少!

比如:target=4

要满足sum>=target并且sum-target为偶数,sum = 1+2+3,要使sum=target,只需要1前取负就行:sum=-1+2+3=4ÿ

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值