leetcode--数组(Medium1)

2019.08.05


3.无重复字符的最长字串

  • 基本思想:双指针哈希表
  • 实现:
    1. 使用 head 指向无重复子串的头,ind 指向当前位置(即当前无重复子串的尾),len_max记录当前无重复字串的最长长度,使用字典的 key 存储串 s 的字符,value 存储字符在串中的位置。
    2. 当 k(当前字符)不在字典中时,表明 k 是当前无重复子串的尾元素,故当前无重复字符的子串长度为( ind - head + 1 ),与最大长度进行比较看是否更新,然后将此 k 放入字典中;
    3. 当 k 已经存在于字典中时,还需判断 字典中的这个 k 的 value(即在串中的位置)是否大于等于 head,(因为 head 是当前无重复子串的首位置)如果小于 head 则认为这个已经存在的 k 早已废弃(与当前无重复子串无关),与 k 不在字典中时的情况一致处理,k 的 value 大于等于 head 则认为遇到了重复元素,k 之前的无重复子串的长度为 ( ind - head ),与最大长度进行比较看是否需要更新,然后 head 跟新为 被重复了的元素 k~ 的下一个位置,这样从 k~ 的下一个位置到当前 k 的位置的子串又是另一个无重复子串,同时更新 k 的 value 值,最后返回依次遍历过程中的最大长度。
    def lengthOfLongestSubstring(self, s: str) -> int:head = 0len_max = 0_dict = {}for ind, k  in enumerate(s):if k in _dict and _dict.get(k) >= head:len_max = (ind - head) if (ind - head) > len_max else len_maxhead = _dict.get(k) + 1_dict[k] = indelse:len_max = (ind - head + 1) if (ind - head + 1) > len_max else len_max_dict[k] = indreturn len_max

15.三数之和

  • 基本思想:双指针回溯
  • 实现:
    1. 找组合思路:固定三个数字中最左数字的指针 a,遍历数组找到每个 a 对应的所有满足nums[a] + nums[b] + nums[c] == 0 的 b,c 组合:
    2. 当 nums[a] > 0 时直接跳出,因为 c > b > a,即三个数字都大于 0,在此k之后不可能找到组合了
    3. 当 a > 0 且 nums[a] == nums[a - 1] 时跳过此数字,因为 nums[a - 1] 的所有组合已经被加入到结果中,本次搜索只会搜索到重复组合。
    4. b,c 分设在数组 [a+1, len(nums)-1] 两端,根据 sum 与 0 的大小关系交替向中间逼近,如果遇到等于 0 的组合则加入 arr 中,需要注意:移动 i,j 需要跳过所有重复值,以避免重复答案被计入 arr。
    def threeSum(self, nums: List[int]) -> List[List[int]]:nums.sort()arr = []for a in range(len(nums)-2):if nums[a] > 0:break# 剪枝操作if a > 0 and nums[a] == nums[a-1]:continueb = a + 1c = len(nums) - 1while b < c:if  nums[a] + nums[b] + nums[c] == 0:arr.append([nums[a], nums[b], nums[c]])b += 1c -= 1while b < c and nums[b] == nums[b-1]:b += 1while b < c and nums[c] == nums[c+1]:c -= 1elif  nums[a] + nums[b] + nums[c] > 0:c -= 1while b < c and nums[c] == nums[c+1]:c -= 1else:b += 1while b < c and nums[b] == nums[b-1]:b += 1return arr

2019.08.06


18.四数之和

  • 基本思想:双指针回溯
  • 实现:可以在三数之和的基础上做,或者找出所有符合条件的四数,再去重。
      def fourSum(self, nums: List[int], target: int) -> List[List[int]]:nums.sort()ans=set()  #去重for i in range(len(nums)-3):  #固定第一个数if i > 0 and nums[i] == nums[i-1]:continue  # 剪枝for j in range(i+1,len(nums)-2): #固定第二个数if j > i+1 and nums[j] == nums[j-1]:continue # 剪枝left=j+1 #左指针right=len(nums)-1 #右指针while(right>left):temp=nums[i]+nums[j]+nums[left]+nums[right]if temp==target:ans.add((nums[i],nums[j],nums[left],nums[right]))left+=1right-=1if temp>target:right-=1 #太大了,右指针左移if temp<target:left+=1 #反之res=[]  #修改返回格式for i in ans:res.append(list(i))return res

2019.08.09


16.最接近的三数之和

  • 基本思想:双指针回溯
  • 实现:在三数之和的基础上设置最小差值,每次出现新的组合时更新最小差值,并保留最小差值时的三数之和。
    def threeSumClosest(self, nums: List[int], target: int) -> int:nums.sort()min_t = sys.maxsizefor i in range(len(nums) - 2):#剪枝操作if i > 0 and nums[i] == nums[i-1]:continueleft = i + 1right = len(nums) - 1while(left < right):sum_t = nums[i] + nums[right] + nums[left]if abs(sum_t - target) < min_t:min_t = abs(sum_t - target) res = sum_tif sum_t > target:right -= 1elif sum_t < target:left += 1else:return sum_treturn res

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

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

相关文章

ICML2020 | 一行代码就能实现的测试集上分技巧

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 苏剑林编 | 夕小瑶在训练模型的时候&#xff0c;我们需要损失函数一直训练到0吗&#xff1f;显然不用。一般来说&#xff0c;我们是用训练集来训练模型&#xff0c;但希望的是验证集的损失越小越好&…

Redis系列教程(七):Redis并发竞争key的解决方案详解

Redis高并发的问题 Redis缓存的高性能有目共睹&#xff0c;应用的场景也是非常广泛&#xff0c;但是在高并发的场景下&#xff0c;也会出现问题&#xff1a; 高并发架构系列&#xff1a;Redis缓存和MySQL数据一致性方案详解 如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难…

技术动态 | 北京大学计算机所邹磊教授研究组开源面向 RDF 知识图谱的自然语言问答系统 gAnswer...

项目网站: http://ganswer.gstore-pku.com/代码地址: https://github.com/pkumod/gAnswerOpenKG发布地址: http://openkg.cn/tool/ganswer研究组主页: http://mod.icst.pku.edu.cn一、KBQA 任务简介基于知识库的自然语言问答 (Question Answering over Knowledge Base, KBQA) 主…

SQL简明数据分析教程

https://blog.csdn.net/heming6666/article/details/78207476 实际案例分析&#xff1a; 一道简单的sql语句题 https://cloud.tencent.com/developer/article/1092199

POJ 2287 田忌赛马(贪心)

文章目录1. 题目1.1 题目链接1.2 题目大意1.3 解题思路2. Accepted 代码1. 题目 1.1 题目链接 http://poj.org/problem?id2287 1.2 题目大意 双方各有n匹战斗力各异的马&#xff0c;分别派出来PK&#xff0c;假设对方先出牌&#xff0c;我方后出&#xff0c;求我方最多能胜…

Python中的 List

关于List&#xff1a;最最最基本操作其他操作上的问题一、如何判断 list 重复二、根据 list 里面的每一个 list 的第一个元素排序三、 一个 list 给另一个 list 赋值四、list 与 nparray五、二维列表按列取元素报错汇总IndexError:list assignment Index out of rangeValueErro…

Netty的实现原理、特点与优势、以及适用场景

高并发编程系列 高并发编程系列&#xff1a;NIO、BIO、AIO的区别&#xff0c;及NIO的应用和框架选型 高并发编程系列&#xff1a;ConcurrentHashMap的实现原理(JDK1.7和JDK1.8) 高并发编程系列&#xff1a;CountDownLatch、Semaphore等4大并发工具类详解 高并发编程系列&…

拒绝无脑吹!从ACL20看预训练缺陷

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 舒意恒、兔子酱以 BERT 为代表作的预训练模型的研究热度一直很高&#xff0c;到 0202 年了&#xff0c;预训练的研究依旧层出不穷&#xff0c;而且 ACL 2020 Best Paper 荣誉提名也选择了这一主题的研究…

论文浅尝 | AMUSE: 基于 RDF 数据的多语言问答语义解析方法

来源&#xff1a;ISWC 2017链接&#xff1a;https://link.springer.com/content/pdf/10.1007%2F978-3-319-68288-4.pdf本文主要关注基于RDF数据的多语言问答任务中&#xff0c;对不同语言问句的语义分析工作。作者提出一种基于DUDES(Dependency-based Underspecified Discourse…

网易2018

网易2018数据分析&#xff08;20道单选3道问答&#xff09; 好评率是会员对平台评价的重要指标。现在需要统计2018年1月1日到2018年1月31日&#xff0c;用户’小明’提交的母婴类目"花王"品牌的好评率&#xff08;好评率“好评”评价量/总评价量&#xff09;: 用户评…

贪心应用--汽车加油次数问题

文章目录1. 问题描述2. 解题思路3. 实现代码4. 测试结果1. 问题描述 已知汽车的油箱额定里程&#xff0c;到目的地的路途中各加油站距起点的距离&#xff0c;求如何加油&#xff0c;让加油的次数最少。 2. 解题思路 每次出发前检查下一个加油站有多远&#xff0c;车子能不能…

Pandas中的元素替换

# 序列中的元素替换 ser pd.Series([0, 1, 2, 3, 4, 5]) print(ser.replace(0, 6)) # 单个元素替换 print(ser.replace([0, 1, 2, 3, 4, 5], [5, 4, 3, 2, 1, 0])) # 列表替换 print(ser.replace({1: 11, 2: 22})) # 字典替换# DataFram中的元素替换 df pd.DataFrame({&qu…

最全多线程经典面试题和答案

Java实现线程有哪几种方式&#xff1f; 1、继承Thread类实现多线程2、实现Runnable接口方式实现多线程3、使用ExecutorService、Callable、Future实现有返回结果的多线程 多线程同步有哪几种方法&#xff1f; Synchronized关键字&#xff0c;Lock锁实现&#xff0c;分布式锁等…

论文浅尝 | Aligning Knowledge Base and Document Embedding Models

本文是我们于苏黎世大学合作的关注与知识图谱和文本对齐的论文&#xff0c;发表于ISWC2018.文本和知识图谱都包含了丰富的信息, 其中知识图谱用结构化的三元组表示信息&#xff0c;文本用自由文本形式表示信息&#xff0c;信息表示的差异给知识图谱和文本融合对齐造成了困难&am…

学会提问的BERT:端到端地从篇章中构建问答对

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 苏剑林机器阅读理解任务&#xff0c;相比不少读者都有所了解了&#xff0c;简单来说就是从给定篇章中寻找给定问题的答案&#xff0c;即“篇章 问题 → 答案”这样的流程&#xff0c;笔者之前也写过一些…

leetcode--数组(Medium2)

2019.08.09 39.组合总数 基本思想&#xff1a;回溯实现&#xff1a; def combinationSum(self, candidates: List[int], target: int) -> List[List[int]]:candidates.sort()n len(candidates)res []def helper(i, tmp_sum, tmp):if tmp_sum > target or i n:return …

玩转算法面试-第四章查找值之leetcod相关笔记

查找问题 4-1,2 两类查找问题 1 查找有无&#xff1a;set 2 查找对应关系&#xff1a;map 常见的四种操作&#xff1a; insert&#xff0c; find&#xff0c; erase&#xff0c; change&#xff08;map&#xff09; 例题 leetcode 349 &#xff1a;给定两个数组&#xff0c;…

分治算法(Divide Conquer)

文章目录1. 分治算法思想2. 应用举例2.1 逆序度3. 分治思想处理海量数据1. 分治算法思想 分治算法的核心思想就是&#xff0c;分而治之&#xff0c;将原问题划分成n个规模较小&#xff0c;并且结构与原问题相似的子问题&#xff0c;递归地解决这些子问题&#xff0c;然后再合并…

史上最全Java多线程面试60题,含答案大赠送!

【BAT必考系列&#xff01;多线程60题】 多线程有什么用&#xff1f; 线程和进程的区别是什么&#xff1f; ava实现线程有哪几种方式&#xff1f; 启动线程方法start&#xff08;&#xff09;和run&#xff08;&#xff09;有什么区别&#xff1f; 怎么终止一个线程&#…

论文浅尝 | Interaction Embeddings for Prediction and Explanation

本文是我们与苏黎世大学合作的工作&#xff0c;将发表于WSDM2019&#xff0c;这篇工作在知识图谱的表示学习中考虑了实体和关系的交叉交互&#xff0c;并且从预测准确性和可解释性两个方面评估了表示学习结果的好坏。给定知识图谱和一个要预测的三元组的头实体和关系&#xff0…