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

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

http://www.xdnf.cn/news/10256.html

相关文章:

  • LeetCode hot100-9
  • 让大模型看得见自己的推理 — KnowTrace结构化知识追踪
  • 时间的基本概念与相关技术三
  • 【六. Java面向对象编程入门指南】
  • HackMyVM-Ephemeral3
  • js数据类型有哪些?它们有什么区别?
  • 吴恩达MCP课程(3):mcp_chatbot
  • NW994NX734美光固态闪存NX737NX740
  • SpringBoot如何实现一个自定义Starter?
  • python创建args命令行分析
  • Halcon
  • 从gitee仓库中恢复IDEA项目某一版本
  • Java基础 Day26
  • NumPy 数组计算:广播机制
  • langchain学习 01
  • enumiax:IAX 协议用户名枚举器!全参数详细教程!Kali Linux教程!
  • Vue 核心技术与实战day06
  • Java并发编程实战 Day 2:线程安全与synchronized关键字
  • JS逆向案例—喜马拉雅xm-sign详情页爬取
  • 【xmb】内部文档148344597
  • HomeKit 基本理解
  • JavaSwing之--为组件添加背景
  • 记忆胶囊应用源码纯开源
  • Linux命令之ausearch命令
  • TDengine 集群运行监控
  • Java中的ConcurrentHashMap的使用与原理
  • C语言 — 动态内存管理
  • 杨辉三角系数
  • 嵌入式学习笔记 - STM32 HAL库以及标准库内核以及外设头文件区别问题
  • 【android bluetooth 协议分析 03】【蓝牙扫描详解 1】【扫描关键函数 btif_dm_search_devices_evt 分析】