码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 到达终点数字


    题目

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

    你可以做一些数量的移动 numMoves :

    每次你可以选择向左或向右移动。
    第 i 次移动(从 i == 1 开始,到 i == numMoves ),在选择的方向上走 i 步。
    给定整数 target ,返回 到达目标所需的 最小 移动次数(即最小 numMoves ) 。

    来源:力扣(LeetCode)
    链接:https://leetcode.cn/problems/reach-a-number
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    解

    1. t a r g e t target target可以根据对称性,只考虑为正。
    2. 模拟这个过程,不停的往target点进行移动,直到超出范围。 超出部分,如果为偶数我们后撤;如果奇数,那么我们接着往前进行移动,使得超范围的步数为偶数,这个取决于我们之前的移动次数。
    3. 推导: x ∗ ( x + 1 ) / 2 ≥ t a r g e t x*(x+1)/2\ge target x∗(x+1)/2≥target,得到 x ≥ ( 2 ∗ t a r g e t + 0.25 ) − 0.5 x\ge \sqrt{(2 * target + 0.25)} - 0.5 x≥(2∗target+0.25) ​−0.5, 向上取整,然后,再分情况讨论。
    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 
            
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
  • 相关阅读:
    stl_stack_queue的模拟实现
    AM@连续函数相关概念和运算性质
    培训学校管理系统之家校管理
    opensql
    K8S精进之路-控制器Deployment-(1)
    羽夏笔记—— AT&T 与 GCC
    隐藏安卓平板状态栏,还你全面屏体验
    解决uniapp微信小程序canvas不能引入字体的问题
    Kyligence 入选 Gartner 指标中台创新洞察报告
    WebRTC系列补充--native重采样
  • 原文地址:https://blog.csdn.net/weixin_42227482/article/details/127693874
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号