LeetCode 754. 到达终点数字
【贪心】分情况讨论,因为坐标轴都是对称的,直接对target取个绝对值,只考虑正方向即可,假设从1累加到n的和为sum:
1.sum == target,直接返回n即可。
2.如果(sum - target)% 2 == 0,那么把其中一个i取负数即可,例如差值为2,就把1取负数,差值为6,就把第3步取负数,还是返回n。
3.如果(sum - target)% 2 == 1,那么再走一步如果为差值为偶数了,就是n 1.
4.如果再走一步还没变成偶数,那再走一步必然是偶数了,因为相邻两个数必定一个奇数一个偶数,此时答案是n 2.
所以如果暴力的话,可以直接for循环个i,去找这个n。
-
class Solution {
-
-
// 10;52
-
-
public int reachNumber(int target) {
-
long sum = -Math.abs(target);
-
int n = (int)1e5;
-
for (int i = 1; i <= n; i ) {
-
sum = i;
-
if (sum >= 0 && sum % 2 == 0) return i;
-
}
-
return -1;
-
}
-
}
通过等差数列求和公式来优化
-
class Solution {
-
-
// 4:45
-
-
public int reachNumber(int target) {
-
int t = Math.abs(target);
-
int n = (int)Math.ceil((Math.sqrt(8 * (long)t 1) - 1)/ 2);
-
long tmp = ((long)n 1) * n / 2 - t;
-
if (tmp % 2 == 0) return n;
-
if ((tmp n 1) % 2 == 0) return n 1;
-
return n 2;
-
}
-
}
-
class Solution {
-
-
typedef long long ll;
-
-
public:
-
int reachNumber(int target) {
-
ll t = abs(target);
-
ll n = ceil((sqrt(1 8 * t) - 1) / 2);
-
ll tmp = (n 1) * n / 2 - t;
-
if (tmp % 2 == 0) return int(n);
-
if ((tmp n 1) % 2 == 0) return int(n 1);
-
return int(n 2);
-
}
-
};
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhgghkgf
系列文章
更多
同类精品
更多
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01 -
怎样阻止微信小程序自动打开
PHP中文网 06-13