当前位置: 首页 > news >正文

hot100 -- 1.哈希系列

1.两数之和

题目:

给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串 的长度。

题解:

方法1:暴力求解

def get_two_sum(nums, target):for i in range(len(nums)):for j in range(i+1, len(nums)):if nums[i] + nums[j] == target:return [i, j]

方法2:哈希表+排序+双指针

import collections
def get_two_sum(nums, target):hash = collections.defaultdict(list)# 用哈希表记录位置for i in range(len(nums)):# if nums[i] not in hash:hash[nums[i]].append(i)print(hash)nums.sort()# 双指针寻找left, right = 0, len(nums) - 1while left < right:if nums[left] + nums[right] == target:return [hash[nums[left]].pop(), hash[nums[right]].pop()]elif nums[left] + nums[right] > target:right -= 1else:left += 1

方法3:哈希表(补数)

def get_two_sum(nums, target):hash = {}for i in range(len(nums)):# 找到补数,直接返回if target - nums[i] in hash:return [hash[target - nums[i]], i]hash[nums[i]] = i

相关文章:

  • AI炼丹日志-26 - crawl4ai 专为 AI 打造的爬虫爬取库 上手指南
  • 第三方软件评测机构如何助力软件品质提升及企业发展?
  • Baklib知识中台驱动服务升级
  • Java基础 Day26
  • android 媒体框架之MediaCodec
  • leetcode hot100刷题日记——31.二叉树的直径
  • [GHCTF 2025]SQL???
  • leetcode hot100刷题日记——32.杨辉三角
  • CppCon 2014 学习: The Implementation of Value Types
  • 深入理解 Java 中的 Unsafe 类:原理、应用与风险
  • Java并发编程实战 Day 1:Java并发编程基础与线程模型
  • [SLAM自救笔记0]:开端
  • 字符串索引、幻读的解决方法
  • 玩客云WS1608控制LED灯的颜色
  • RLHF奖励模型的训练
  • 【Qt】EventFilter,要增加事件拦截器才能拦截到事件
  • 数据库只更新特定字段的两种方式(先读后写 vs. 动态组织 SQL)-golang SQLx 实现代码(动态组织 SQL)
  • 【设计模式-4.6】行为型——状态模式
  • 电路学习(二)之电容
  • Win10 doccano pip安装笔记
  • 建设银行网网站打不开/我赢网客服系统
  • 怎样才能做好网站优化/武汉好的seo优化网
  • 番禺做网站技术/花西子网络营销案例分析
  • wordpress获取时间/seowhy官网
  • 互联网舆情/seo是什么部门
  • 网站建设及运营服务流程/福州网络推广运营