首页 > 其他分享 >Leetcode刷题第五天-二分法-回溯

Leetcode刷题第五天-二分法-回溯

时间:2024-01-29 22:22:21浏览次数:25  
标签:return nums int self 二分法 re path Leetcode 刷题

215:第k个最大元素

链接:215. 数组中的第K个最大元素 - 力扣(LeetCode)

em~~怎么说呢,快速选择,随机定一个目标值,开始找,左边比目标小,右边比目标大,左右同时不满足时,交换左右位置,直到左指针比右指针大,交换目标和右指针位置的值,此时右指针位置即时目标值的在排序好数组中的位置,如果k在右边,左边界右移,k在左边,右边界左移

快排

 1 class Solution:
 2     def findKthLargest(self, nums: List[int], k: int) -> int:
 3         if(not nums):   return 0
 4         lens=len(nums)
 5         #倒数第k大,正数位置lens-k
 6         tager=lens-k
 7         left,right=0,lens-1
 8         while left<=right:
 9             i,j=left+1,right
10             flage=0
11             while i<=j:
12                 #如果左大于目标,并且右小于目标,交换左右
13                 if(nums[i]>=nums[left] and nums[j]<=nums[left]):   
14                     nums[i],nums[j]=nums[j],nums[i]
15                     i+=1
16                     j-=1
17                 else:
18                     #左小于目标,左+1,右大于目标,右-1
19                     if(nums[i]<=nums[left]):    i+=1
20                     if(nums[j]>=nums[left]):    j-=1
21             #目标比右大,交换目标和右
22             nums[left],nums[j]=nums[j],nums[left]
23             #如果结束的位置是tager,结束,大了找左,小了找右
24             if(j==tager):   return nums[j]
25             elif(j>tager):  right=j-1
26             else:   left=j+1
findKthLargest

347:前k个高频元素

链接:347. 前 K 个高频元素 - 力扣(LeetCode)

em~~没啥

 1 class Solution:
 2     def topKFrequent(self, nums: List[int], k: int) -> List[int]:
 3         if(not nums):   return nums
 4         data={x:0 for x in nums}
 5         for item in data:
 6             data[item]+=nums.count(item)
 7         data=sorted(data.items(),key=lambda x:x[1] ,reverse=True)
 8         re=[]
 9         for i in range(k):
10             re.append(data[i][0])
11         return re
12         
topKFrequent

451:根据字符出现频率排序

链接451. 根据字符出现频率排序 - 力扣(LeetCode)

347一样

 1 class Solution:
 2     def frequencySort(self, s: str) -> str:
 3         data={x:0 for x in s}
 4         for item in data:
 5             data[item]+=s.count(item)
 6         data=sorted(data.items(),key=lambda x:x[1],reverse=True)
 7         re=''
 8         for item in data:
 9             re+=item[0]*item[1]
10         return  re
frequencySort

75:颜色分类

链接:75. 颜色分类 - 力扣(LeetCode)

后一个数小于前一个,交换,i-1,否做i+1

 1 class Solution:
 2     def sortColors(self, nums: List[int]) -> None:
 3         """
 4         Do not return anything, modify nums in-place instead.
 5         """
 6         if (not nums):  return nums
 7         lens=len(nums)
 8         i=1
 9         while i<lens:
10             if(i==0):   i+=1
11             if(nums[i]<nums[i-1]):
12                 nums[i],nums[i-1]=nums[i-1],nums[i]
13                 i-=1
14             else:
15                 i+=1
16         print(nums)
sortColors

开启回溯之旅

回溯理论知识引用:代码随想录 (programmercarl.com)

 

void backtracking(参数) {
    if (终止条件) {
        存放结果;
        return;
    }

    for (选择:本层集合中元素(树中节点孩子的数量就是集合的大小)) {
        处理节点;
        backtracking(路径,选择列表); // 递归
        回溯,撤销处理结果
    }
}

77:组合

链接:77. 组合 - 力扣(LeetCode)

for i in (1,2,3,4)遍历

递归:每个结果长度=k,结束递归

 1 class Solution:
 2     def combine(self, n: int, k: int) -> List[List[int]]:
 3         if(n==0):   return []
 4         re=[]
 5         self.backtracking(n+1,k,1,[],re)
 6         return re
 7     def backtracking(self,n,k,startId,path,re):
 8         if(len(path)==k):    
 9             re.append(path[:])
10             return
11         for i in range(startId,n):
12             path.append(i)
13             self.backtracking(n,k,i+1,path,re)
14             path.pop()
combine
 1 class Solution:
 2     def combine(self, n: int, k: int) -> List[List[int]]:
 3         if(n==0):   return []
 4         re=[]
 5         self.backtracking(n+1,k,1,[],re)
 6         return re
 7     def backtracking(self,n,k,startId,path,re):
 8         if(len(path)==k):    
 9             re.append(path[:])
10             return
11         #说实话,这步减枝优化没看懂,在找一道题试试
12         #for i in range(startId,n-(k-len(path))+1):
13         for i in range(startId,n):
14             print(i,path)
15             path.append(i)
16             self.backtracking(n,k,i+1,path,re)
17             path.pop()
combine(优化)

216:组合总和III

链接:216. 组合总和 III - 力扣(LeetCode)

for i in (1-9)遍历

递归:相加,和大于n直接返回,小于n放入单次结果中

 1 class Solution:
 2     def combinationSum3(self, k: int, n: int) -> List[List[int]]:
 3         if(not k or not n): return[]
 4         re=[]
 5         self.backtracking(1,n,k,[],re)
 6         return re
 7     def backtracking(self,startId,n,k,path,re):
 8         if(len(path)==k):
 9             if(sum(path)==n):
10                 re.append(path[:])
11             return
12         for i in range(startId,10-(k-len(path))):
13             #如果和大于n,后面就没有必要做了,小于n
14             if(i+sum(path)<=n):
15                 path.append(i)
16                 self.backtracking(i+1,n,k,path,re)
17                 path.pop()
18             else:   return
combinationSum3

17:电话号码的字母组合

链接:17. 电话号码的字母组合 - 力扣(LeetCode)

for  i in (一个数字对应的字母表)遍历

递归:单次结果的字符串按digits顺序相加

 1 dicts={2:'abc',3:'def',4:'ghi',5:'jkl',6:'mno',7:'pqsr',8:'tuv',9:'wxyz'}
 2 class Solution:
 3     def letterCombinations(self, digits: str) -> List[str]:
 4         if(not digits): return []
 5         re=[]
 6         self.backtracking(digits,'',re,0)
 7         return re
 8     def backtracking(self,digits,path,re,index):
 9         global dicts
10         if(index==len(digits)):
11             re.append(path)
12             return
13         for strs in dicts[int(digits[index])]:
14             self.backtracking(digits,path+strs,re,index+1)
15 
16 
17         
letterCombinations

39:组合总和

链接:39. 组合总和 - 力扣(LeetCode)

还是要传个index,第一个元素的下标,当前元素可以重复用,但是不能回头往前找

 1 class Solution:
 2     def combinationSum(self, candidates: List[int], target: int) -> List[List[int]]:
 3         if(not candidates): return []
 4         re=[]
 5         self.backtracking(candidates,target,[],re,0)
 6         return re
 7     def backtracking(self,candidates,target,path,re,index):
 8         if(sum(path)==target):
 9             re.append(path[:])
10             return
11         for i in range(index,len(candidates)):
12             num=candidates[i]
13             if(sum(path)<target):
14                 path.append(num)
15                 self.backtracking(candidates,target,path,re,i)
16                 path.pop()
17             else:   return
combinationSum

40:组合总和II

链接:40. 组合总和 II - 力扣(LeetCode)

需要注意的是:每一层不能重复使用相同的元素,但是下一层可以重复用

 1 class Solution:
 2     def combinationSum2(self, candidates: List[int], target: int) -> List[List[int]]:
 3         if(not candidates): return []
 4         candidates.sort()
 5         re=[]
 6         self.backtracking(candidates,target,[],re,0)
 7         return re
 8     def backtracking(self,candidates,target,path,re,index):
 9         if(sum(path)==target):
10             re.append(path[:])
11             return
12         for i in range(index,len(candidates)):
13             #每一次的迭代元素,不能重复,但是下一层递归中可以用
14             if(i>index and candidates[i]==candidates[i-1] ): continue
15             if(sum(path)<target):
16                 path.append(candidates[i])
17                 self.backtracking(candidates,target,path,re,i+1)
18                 path.pop()
19             else:   return 
combinationSum2

 

标签:return,nums,int,self,二分法,re,path,Leetcode,刷题
From: https://www.cnblogs.com/xiaoruru/p/17995494

相关文章

  • 每日刷题 绘制表格
    一.题目在中文Windows环境下,控制台窗口中也可以用特殊符号拼出漂亮的表格来。比如:┌─┬─┐│││├─┼─┤│││└─┴─┘其实,它是由如下的符号拼接的:左上=┌上=┬右上=┐左=├中心=┼右=┤左下=└下=┴右下=┘垂直=│水平=─......
  • [刷题笔记] 关于栈 & 队列常用操作方法的再探索
    Part0:序其实本来这都是很基础的东西,可惜野路子出身基础并不扎实。借着这个机会整合一下吧。也做了一些题了解了一些基本操作方法。本文对于栈和队列的原理不再过多赘述,默认读者掌握基本原理。参考题单:数据结构加强001:栈和队列2024现代信息学测试1:栈和队列本文所讲例题......
  • leetcode--98. 验证二叉搜索树(bfs)
    记录13:502024-1-28https://leetcode.cn/problems/validate-binary-search-tree/想岔方向了,想的太复杂了。首先思路是每个root节点必须大于左子树的最大节点,小于右边子树的最小节点。我的做法是记录下叶子节点,因为左边叶子节点的集合(vector)的最后一个节点为左子树的最大值......
  • Leetcode刷题第四天-双指针-二分法
    15:三个数之和链接:15.三数之和-力扣(LeetCode)em...双冲for循环,从头去遍历,0-(a+b)是否在列表中,最终timeout数组从小到大排序,设置三个指针,i从头遍历到lens-1,j从i+1开始,k从lens-1开始,sums==0,放入结果,大于0,k-1,小于0,j+1如果i和i+1比较,相同跳过的话,会丢结果,i和i-1相等跳过,因为i-1已......
  • [LeetCode] 2859. Sum of Values at Indices With K Set Bits
    Youaregivena0-indexedintegerarraynumsandanintegerk.Returnanintegerthatdenotesthesumofelementsinnumswhosecorrespondingindiceshaveexactlyksetbitsintheirbinaryrepresentation.Thesetbitsinanintegerarethe1'sprese......
  • 码农面试宝典之leetcode刷题手册
    今年的经济形势和行业状况可以说对求职者来说很不友好,你们是否曾因为面对编程面试题而感到迷茫?是否渴望提升自己的算法技能顺利跨入大厂?让我向你们推荐一项强大的利器——LeetCode刷题手册,它将成为你找到理想工作的秘密武器。LeetCode作为全球最受欢迎的在线编程平台之一,不仅拥有......
  • #yyds干货盘点# LeetCode程序员面试金典:和为 K 的子数组
    题目给你一个整数数组nums和一个整数k,请你统计并返回该数组中和为k的子数组的个数。子数组是数组中元素的连续非空序列。 示例1:输入:nums=[1,1,1],k=2输出:2示例2:输入:nums=[1,2,3],k=3输出:2 代码实现publicclassSolution{publicintsubarr......
  • #yyds干货盘点# LeetCode程序员面试金典:左叶子之和
    题目给定二叉树的根节点root,返回所有左叶子之和。 示例1:输入:root=[3,9,20,null,null,15,7] 输出:24 解释:在这个二叉树中,有两个左叶子,分别是9和15,所以返回24示例2:输入:root=[1]输出:0代码实现classSolution{publicintsumOfLeftLeaves(Tr......
  • Leetcode刷题第三天-贪心-双指针
    738:单调递增链接:738.单调递增的数字-力扣(LeetCode)嘶~介个介个恶心心,从后往前遍历,前一个数比当前数大,前一个数-1,当前数变为9需要注意的是,保证每个9后面全是9100,第一轮遍历完时90T_T1classSolution:2defmonotoneIncreasingDigits(self,n:int)->int:3......
  • C# 二分法查询代码
    二分法查找,也称为折半法,是一种在有序数组中查找特定元素的搜索算法。使用二分法的前提条件是:在有序数组中查找特定元素publicstaticintSearchInsert(int[]nums,inttarget){intstart=0;//开始索引intend=nums.Length-1;//结束索引i......