力扣Hot100之两数之和

解法一:

双层循环暴力求解,先在数组的一个位置定住然后在这个位置的后续位置进行判断,如果两个数加起来等于目标和那么就返回

class Solution:def twoSum(self, nums: List[int], target: int) -> List[int]:for i,num in enumerate(nums):for j,secdnum in enumerate(nums[i+1:]):if num+secdnum==target:a=[]a.append(i)a.append(i+1+j)return a

注意第二个的index得是i+1+j,i+1表示从第i后面一个数开始,j表示二层循环的个数

解法二:

用哈希表,key存值,value存index,当target-num存在表中时直接返回。第一个方法时间复杂度高就算因为寻找target-num时间复杂度过高,但是这个方法只用遍历一次数组把寻找target-x的时间复杂度从O(N)降低到O(1).

class Solution:def twoSum(self, nums: List[int], target: int) -> List[int]:hashtable=dict()for i,num in enumerate(nums):if target-num in hashtable:return [hashtable[target-num],i]hashtable[nums[i]]=ireturn []

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/46892.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Laravel队列的魔法:高效异步任务处理指南

Laravel队列的魔法:高效异步任务处理指南 在现代Web应用开发中,异步任务处理是提升用户体验和应用性能的关键技术之一。Laravel框架内置了一个强大的队列系统,允许开发者将耗时的任务如发送邮件、处理数据等放入队列中异步执行。本文将深入探…

Windows 系统利用 SSH 和 WSL2 子系统当服务器

由于最近组内需要将一台 Windows 系统的电脑 W A W_A WA​ 转成能通过 SSH 访问,并且能用 Linux 命令当服务器运行。忙活了一天,终于是把全部东西弄通了。 安装 SSH 首先就是 W A W_A WA​ 先要安装 OpenSSH 服务,直接按照下面的教程安装…

HCIE是什么等级的证书?

HCIE(华为认证互联网专家,Huawei Certified Internetwork Expert)是华为认证体系中的最高等级证书。它要求考生具备在复杂网络环境中规划、设计、部署、运维和优化网络的能力。HCIE认证是华为认证体系中最具挑战性和含金量的认证之一&#xf…

RocketMQ实现分布式事务

RocketMQ的分布式事务消息功能,在普通消息基础上,支持二阶段的提交。将二阶段提交和本地事务绑定,实现全局提交结果的一致性。 1、生产者将消息发送至RocketMQ服务端。 2、RocketMQ服务端将消息持久化成功之后,向生产者返回Ack确…

NDK R25b 交叉编译FFMpeg4,项目集成,附库下载地址

1.准备工作 文件下载: NDK R25b下载地址:Android NDK历史版本下载网址 - 君*邪 - 博客园 (cnblogs.com) FFmpeg4.4.4 下载地址:https://ffmpeg.org/releases/ffmpeg-4.4.4.tar.xz 环境配置: 本次编译环境是在PC虚拟机中使用U…

普通人还有必要学习 Python 之类的编程语言吗?

在开始前分享一些编程的资料需要的同学评论888即可拿走 是我根据网友给的问题精心整理的对于编程的重要性,这里就不详谈了。 未来,我们和机器的交流会越来越多,编程可以简单看作是和机器对话并分发给机器任务。机器不仅越来越强大&#xff0…

QT下,如何获取控制台输入

最近工作中为了测试某个模块&#xff0c;需要把原先输入模块部分&#xff0c;改成控制台输入来方便测试。在QT中&#xff0c;我们可以使用 QTextStream 类来读取用户的输入来达到目的。下面是一个简单的例子&#xff1a; #include <QCoreApplication> #include <QTex…

C# —— CRC16 算法

CRC16:即循环冗余校验码。数据通信当中一种常用的查错校验码 其特征信息字段和校验字段的长度可以是任意选定的&#xff0c;对数据进行指定多项式计算 并且将得到的结果附加在帧的后面&#xff0c;接受的设备也执行类似的算法&#xff0c;以保证数据传输的正确性和完整性 crc…

Laravel的魔法纽带:深入理解Eloquent ORM的关联(Relationships)

Laravel的魔法纽带&#xff1a;深入理解Eloquent ORM的关联&#xff08;Relationships&#xff09; 在Laravel的世界中&#xff0c;Eloquent ORM&#xff08;对象关系映射&#xff09;是连接数据库和应用程序代码的桥梁。通过Eloquent&#xff0c;你可以轻松地定义和管理数据库…

鸿蒙语言基础类库:【@system.configuration (应用配置)】

应用配置 说明&#xff1a; 从API Version 7 开始&#xff0c;该接口不再维护&#xff0c;推荐使用新接口[ohos.i18n]和[ohos.intl]。本模块首批接口从API version 3开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。 导入模块 import configurati…

数据库安装部署教程

数据库的安装部署教程因不同的数据库管理系统&#xff08;DBMS&#xff09;而异&#xff0c;以下将以MySQL、SQL Server和Oracle为例&#xff0c;分别概述其安装部署的基本步骤。请注意&#xff0c;由于软件版本和操作系统的不同&#xff0c;具体步骤可能会有所变化。 一、MyS…

CSS Modules:重构前端样式的未来?

在前端开发领域&#xff0c;CSS Modules 是近年来备受关注的一种样式解决方案&#xff0c;它改变了传统 CSS 的全局共享模式&#xff0c;引入了一种局部作用域的概念。这种变化不仅提升了样式的可维护性和可复用性&#xff0c;还促进了组件化开发的进一步成熟。本文将深入探讨 …

常见CSS属性

常见CSS属性。 1. display: 定义&#xff1a;display 属性控制元素如何渲染在文档流中&#xff0c;影响了元素是否占用空间、位置及盒子模型的行为。 使用说明&#xff1a;它可以设置为如block, inline, inline-block, flex, grid, none等值&#xff0c;用于决定元素显示模式…

云服务器实际内存与购买不足量问题

君衍 一、本篇缘由二、问题研究1、dmidecode2、dmesg | grep -i memory 三、kdump四、解决方案1、卸载kdump-tools2、清理依赖包3、修改配置文件4、重新生成配置文件5、重启服务器6、再次查看 一、本篇缘由 本篇由于最近买了云服务器&#xff0c;之前基本在本地使用VMware进行虚…

web自动化测试selenium的基本使用

目录 初始化浏览器并打开网页 定位网页元素 定位的方法 模拟键盘操作 模拟鼠标操作 xpath方法 xpath结点 路径表达式 轴 selenium是一个很流行的自动化测试的库&#xff0c;主要用于模拟浏览器的运行&#xff0c;是web应用测试的工具。 在使用selenium时&#xff0c;…

复变偏微分方程

复变偏微分方程是一类在复数域上定义的偏微分方程。这类方程在数学物理、工程学、流体力学等领域有着广泛的应用。复变函数理论为解决这类方程提供了强有力的工具。 ### 基本定义 复变偏微分方程通常涉及复数域上的函数 \( f(z, \bar{z}) \)&#xff0c;其中 \( z \) 是复变量…

网络安全----web安全防范

以下代码用来防范流行的DDoS攻击&#xff0c;ARP欺骗&#xff0c;CC攻击&#xff0c;XXS攻击&#xff0c;对输入的恶意代码进行过滤&#xff0c;嵌入到web程序可以很好的防范网络攻击&#xff0c;但如果想要更好的防范网络攻击&#xff0c;还需要更加复杂的配置和更硬核的硬件。…

(二)高并发压力测试调优篇——caffeine本地缓存调优

前言 在上一节内容中我们主要介绍了高并发请求下&#xff0c;mysql数据库的调优&#xff0c;其调优的主要原理是尽量减少数据库的IO操作&#xff0c;从而提高服务器的访问性能。在此基础上&#xff0c;本节内容是关于如何利用缓存&#xff0c;提高系统的并发访问能力。我们会首…

Linux部署禅道(无脑复制版)

目录 环境部署1、下载&#xff0c;解压2、启动3、设置开机自启 登录禅道登录数据库1、设置账号2、网页登录数据库 环境 Linux系统 Centos7 《Linux一键安装包安装禅道》视频链接&#xff1a; https://www.zentao.net/zentao-install/zentao-linux-install-80523.html 部署 …