Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱
MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina.com

领扣-754 到达终点数字 Reach a Number MD


目录

到达终点数字 Reach a Number MD

题目

在一根无限长的数轴上,你站在0的位置。终点在target的位置。

You are standing at position 0 on an infinite number line. There is a goal at position target.

每次你可以选择向左 向右移动。第 n 次移动(从 1 开始),可以走 n 步。

On each move, you can either go left or right. During the n-th move (starting from 1), you take n steps.

返回到达终点需要的最小移动次数。

Return the minimum number of steps required to reach the destination.

示例 1:

输入: target = 3
输出: 2
解释:
第一次移动,从 0 到 1 。
第二次移动,从 1 到 3 。

示例 2:

输入: target = 2
输出: 3
解释:
第一次移动,从 0 到 1 。
第二次移动,从 1 到 -1 。
第三次移动,从 -1 到 2 。

思路

首先

比如说目标值是4,那么如果我们一直向前走,直到累加步数 sum 正好大于等于target时,有:

0 + 1 = 1

1 + 2 = 3

3 + 3 = 6

我们发现 sum 超过了目标值 4,超过的距离为2,是偶数,那么实际上我们只要将加上距离为 1 的时候,不加 1,而是 -1,那么此时累加和就损失了 2,那么正好能到目标值 4,如下:

0 - 1 = -1

-1 + 2 = 1

1 + 3 = 4

所以这种情况下,最小的步数就是累加步数到 sum 所用的步数 n。


然后

如果说目标值是 7,有:

0 + 1 = 1

1 + 2 = 3

3 + 3 = 6

6 + 4 = 10

我们发现 sum 超过了目标值 7 的距离为3,是奇数,我现在可以这么处理这个奇数 3:

3 = 2 * 1 + 1

前面的偶数 2 可以按照上面的方式来处理,我只需要处理多出来的 1 即可。实际上 1 就很好处理了,我们只需再向前走 1 步,然后再向后走 1 步其实刚好就抵消了这个 1 。这个过程如下:

0 - 1 = -1

-1 + 2 = 1

1 + 3 = 4

4 + 4 = 8 //基准步数

8 + 5 = 13

13 - 6 = 7

所以这种情况下,最小的步数就是累加步数到 sum 所用的步数 n + 2。


然而

然而测试时发现,当 sum - target 为奇数时,某些情况下,我们这种方式的步数会比最优解大 1 ,就比如上面的目标值 7 。

下面我们分析一下。

target=7; sum=10; n=4;

我们再走一步的话 sum=7+5=15; sum-target=8;

看到没,我们再走一步之后 sum-target 变成偶数了,既然变成偶数了,我们当然就可以按照最初的方式来走了呀:

0 + 1 = 1

1 + 2 = 3

3 + 3 = 6

6 - 4 = 2 //基准步数

2 + 5 = 7

所以这种情况下,我们只需多走一步就可以了,不需要无脑的多走两步。


所以

上面当 sum - target 为奇数时多走一步就可以的条件是:

sum + (n+1) - target 为偶数

因为我们已经知道 sum - target 为奇数了,所以 n+1 肯定也为奇数,也就是说 n 为偶数。

也就是说,如果此时 n 为偶数,我们只需再多走一步就可以了。

那如果 n 为奇数呢?

我觉得有两种分析方式,一种就是我们上面最开始错误分析的那种,直接为 n + 2;另一种可以继续按照这种方式分析:

如果 tem = sum - target 为奇数

那么 tem + (n+1) + (n+2) = 2 (n+1) + (tem+1) 肯定为偶数,也即再多走 2 步 无论如何都是可以的了。

当然,这只能保证是可以到达终点的路径,但不能百分之百保证这是最佳的路径!

代码实现

class Solution {
public int reachNumber(int target) {
target = Math.abs(target); //处理负值的情况
int count = 0;
int sum = 0;
while (sum < target) {
count++;
sum += count;
}
if ((sum - target) % 2 != 0) {
if (count % 2 == 0) {
count += 1;
} else {
count += 2;
}
}
return count;
}
}

2018-12-7

领扣-754 到达终点数字 Reach a Number MD的更多相关文章

  1. [Swift]LeetCode754. 到达终点数字 | Reach a Number

    You are standing at position 0 on an infinite number line. There is a goal at position target. On ea ...

  2. Java实现 LeetCode 754 到达终点数字(暴力+反向)

    754. 到达终点数字 在一根无限长的数轴上,你站在0的位置.终点在target的位置. 每次你可以选择向左或向右移动.第 n 次移动(从 1 开始),可以走 n 步. 返回到达终点需要的最小移动次数 ...

  3. 领扣-1/167 两数之和 Two Sum MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  4. LeetCode 754. Reach a Number到达终点数字

    题目 在一根无限长的数轴上,你站在0的位置.终点在target的位置. 每次你可以选择向左或向右移动.第 n 次移动(从 1 开始),可以走 n 步. 返回到达终点需要的最小移动次数. 示例 1: 输 ...

  5. 领扣(LeetCode)数字转换为十六进制数 个人题解

    给定一个整数,编写一个算法将这个数转换为十六进制数.对于负整数,我们通常使用 补码运算 方法. 注意: 十六进制中所有字母(a-f)都必须是小写. 十六进制字符串中不能包含多余的前导零.如果要转化的数 ...

  6. 到达一个数 Reach a Number

    2018-09-24 14:19:58 问题描述: 问题求解: 初看到这个问题,直觉上认为可以通过BFS遍历解空间进行求解,因为本质上来说,这个问题和棋盘上移动马的问题是一类问题,都是可以转化成图的问 ...

  7. LeetCode 754. Reach a Number

    754. Reach a Number(到达终点数字) 链接:https://leetcode-cn.com/problems/reach-a-number/ 题目: 在一根无限长的数轴上,你站在0的 ...

  8. 领扣-121/122/123/188 最佳买卖时机 Best Time to Buy and Sell MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  9. 领扣-209 长度最小的子数组 Minimum Size Subarray Sum MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

随机推荐

  1. 【BZOJ 4819】 4819: [Sdoi2017]新生舞会 (0-1分数规划、二分+KM)

    4819: [Sdoi2017]新生舞会 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 601  Solved: 313 Description 学校 ...

  2. BZOJ.4456.[ZJOI2016]旅行者(分治 Dijkstra)

    题目链接 \(Description\) 给定\(n\times m\)的带边权网格图.\(Q\)次询问从点\((x_i,y_i)\)到点\((x_j,y_j)\)的最短路. \(n\times m\ ...

  3. BZOJ.1017.[JSOI2008]魔兽地图(树形DP 背包DP)

    题目链接 树形DP,考虑子节点对父节点的贡献. 设f[x][i][j]表示当前为x,用i个x去合成上一层装备,花费为j的最大价值. 由子节点转移时 是一个分组背包,需要一个辅助数组g[i][j]表示前 ...

  4. Codeforces Round #371 (Div. 2) A. Meeting of Old Friends 水题

    A. Meeting of Old Friends 题目连接: http://codeforces.com/contest/714/problem/A Description Today an out ...

  5. JS在在线人数和访问人数

    var date=new Date();var expiresDays=10;var count=1500+parseInt(date.getTime()/1000)-parseInt(date.ge ...

  6. Oracle数据库日期范围查询的两种实现方式

    参考文档:http://database.51cto.com/art/201108/288058.htm Oracle数据库日期范围查询有两种方式:to_char方式和to_date方式,接下来我们通 ...

  7. 我是该学JAVA呢,还是学IOS开发呢?

    摘要: iOS就像Andriod一样,不是编程语言,而是操作系统.学iOS开发,其实学的是如何用Objective-C在苹果操作系统上进行各种应用程序的开发.就像学Andriod开发,其实是学如何用J ...

  8. MyEclipse10安装Log4E插件

    一. Log4E插件下载 下载地址:http://log4e.jayefem.de/content/view/3/2/ 二.安装Log4E插件 将下载下来的压缩包解压缩,如下图所示: 解压缩生成的[d ...

  9. C#写UTF8文件时指定是否含BOM头

    BOM的基本概念 在UCS 编码中有一个叫做"ZERO WIDTH NO-BREAK SPACE"的字符,它的编码是FEFF.而FFFE在UCS中是不存在的字符,所以不应该出现在实 ...

  10. 淡淡理解下AngularJS中的module

    在AngularJS中module是一个核心的存在,包括了很多方面,比如controller, config, service, factory, directive, constant, 等等. 在 ...