Leetcode 754. Reach a Number [Python]

2023-12-22 21:08
文章标签 python leetcode number 754 reach

本文主要是介绍Leetcode 754. Reach a Number [Python],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先来一个BFS吧,可以想做一个binary tree,root是0.左侧子树是0-1,右侧是0+1.然后每一层的边的权重比上一层+1.也就是第二层节点是-1,1,其左子是 - 1 -2,-1+2以及1-2和1+2. 找到target时,返回层数-1.这样做会TLE。

class Solution:def reachNumber(self, target: int) -> int:level = 1que = collections.deque()que.append(0)while que:size = len(que)for _ in range(size):curpos = que.popleft()if curpos == target:return level - 1newpos1 = curpos + levelnewpos2 = curpos - levelque.append(newpos1)que.append(newpos2)level += 1return -1

接下来是binary search版本

class Solution:def reachNumber(self, target: int) -> int:target = abs(target)r = targetl = 1while r > l:mid = l + (r- l)//2#sumif (1 + mid)*mid//2 < target:l = mid + 1else:r = mid#cursum:overpart = (l + 1)*l//2 - targetwhile overpart%2:overpart += l + 1l += 1return l

从每次增加的量入手,第一次增加1,第二次2,一直增加的总和到某一个数,也就是走的步数n,那最后停留(只看+的)的位置为1+2+3+4.。。。+n,计算为(1+n)*n//2. 假设n为binary search的目标值,l =0,r = target。当我们计算的到的mid ->n,使得(1+n)*n//2 大于target值后,我们尝试增加下一步(步数+1),直到使得超过target的部分为偶数,超过部分为overpart,则我们其实上再需要多走一步,-overpart/2,这样,总量增加量实际上要减去+的overpart/2,并且还要增加一个-的overpart/2。

这篇关于Leetcode 754. Reach a Number [Python]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/525483

相关文章

浅析Python中的绝对导入与相对导入

《浅析Python中的绝对导入与相对导入》这篇文章主要为大家详细介绍了Python中的绝对导入与相对导入的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1 Imports快速介绍2 import语句的语法2.1 基本使用2.2 导入声明的样式3 绝对import和相对i

Python中配置文件的全面解析与使用

《Python中配置文件的全面解析与使用》在Python开发中,配置文件扮演着举足轻重的角色,它们允许开发者在不修改代码的情况下调整应用程序的行为,下面我们就来看看常见Python配置文件格式的使用吧... 目录一、INI配置文件二、YAML配置文件三、jsON配置文件四、TOML配置文件五、XML配置文件

Python中conda虚拟环境创建及使用小结

《Python中conda虚拟环境创建及使用小结》本文主要介绍了Python中conda虚拟环境创建及使用小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录0.前言1.Miniconda安装2.conda本地基本操作3.创建conda虚拟环境4.激活c

使用Python创建一个能够筛选文件的PDF合并工具

《使用Python创建一个能够筛选文件的PDF合并工具》这篇文章主要为大家详细介绍了如何使用Python创建一个能够筛选文件的PDF合并工具,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录背景主要功能全部代码代码解析1. 初始化 wx.Frame 窗口2. 创建工具栏3. 创建布局和界面控件4

一文详解如何在Python中使用Requests库

《一文详解如何在Python中使用Requests库》:本文主要介绍如何在Python中使用Requests库的相关资料,Requests库是Python中常用的第三方库,用于简化HTTP请求的发... 目录前言1. 安装Requests库2. 发起GET请求3. 发送带有查询参数的GET请求4. 发起PO

Python与DeepSeek的深度融合实战

《Python与DeepSeek的深度融合实战》Python作为最受欢迎的编程语言之一,以其简洁易读的语法、丰富的库和广泛的应用场景,成为了无数开发者的首选,而DeepSeek,作为人工智能领域的新星... 目录一、python与DeepSeek的结合优势二、模型训练1. 数据准备2. 模型架构与参数设置3

Python进行PDF文件拆分的示例详解

《Python进行PDF文件拆分的示例详解》在日常生活中,我们常常会遇到大型的PDF文件,难以发送,将PDF拆分成多个小文件是一个实用的解决方案,下面我们就来看看如何使用Python实现PDF文件拆分... 目录使用工具将PDF按页数拆分将PDF的每一页拆分为单独的文件将PDF按指定页数拆分根据页码范围拆分

Python中常用的四种取整方式分享

《Python中常用的四种取整方式分享》在数据处理和数值计算中,取整操作是非常常见的需求,Python提供了多种取整方式,本文为大家整理了四种常用的方法,希望对大家有所帮助... 目录引言向零取整(Truncate)向下取整(Floor)向上取整(Ceil)四舍五入(Round)四种取整方式的对比综合示例应

python 3.8 的anaconda下载方法

《python3.8的anaconda下载方法》本文详细介绍了如何下载和安装带有Python3.8的Anaconda发行版,包括Anaconda简介、下载步骤、安装指南以及验证安装结果,此外,还介... 目录python3.8 版本的 Anaconda 下载与安装指南一、Anaconda 简介二、下载 An

Python自动化处理手机验证码

《Python自动化处理手机验证码》手机验证码是一种常见的身份验证手段,广泛应用于用户注册、登录、交易确认等场景,下面我们来看看如何使用Python自动化处理手机验证码吧... 目录一、获取手机验证码1.1 通过短信接收验证码1.2 使用第三方短信接收服务1.3 使用ADB读取手机短信1.4 通过API获取