力扣——算法入门计划第十一天

简介: 力扣(LeetCode)是领扣网络旗下专注于程序员技术成长和企业技术人才服务的品牌。源自美国硅谷,力扣为全球程序员提供了专业的IT技术职业化提升平台,有效帮助程序员实现快速进步和长期成长。 此外,力扣(LeetCode)致力于解决程序员技术评估、培训、职业匹配的痛点,逐步引领互联网技术求职和招聘迈向专业化。

 目录

🍕题目

🍔回溯

🍟代码

🍕题目

🍔思路

🍟代码

🍕题目

🍔思路

🍟代码


🍕题目

77. 组合

image.png

🍔回溯

1)先确定边界条件,if len(path) == k:
               res.append(path[:])

2)  dfs(i + 1, path + [i])  递归下一个元素

🍟代码

class Solution:
    def combine(self, n: int, k: int) -> List[List[int]]:
        def dfs(start, path):
            if len(path) == k:
                res.append(path)
                return
            upper_bound = n - (k - len(path)) + 1
            for i in range(start, upper_bound + 1):
                dfs(i + 1, path + [i])
        res = []
        dfs(1, [])
        return res

image.gif

image.png

🍕题目

46. 全排列

image.gifimage.png

🍔思路

image.png

path记录结果,cand.....没用过的元素   最上面 不断遍历的数字

利用切片将i元素去掉

🍟代码

class Solution:
    def permute(self, nums: List[int]) -> List[List[int]]:
        if len(nums) <= 1: return [nums]
        self.res = []
        def recur(path,cand):
            if len(cand)  == 0:
                self.res.append(path)
            for i,n in enumerate(cand):
                recur(path+[n],cand[:i]+cand[i+1:])
        recur([],nums)
        return self.res

image.gif

image.gifimage.png

🍕题目

784. 字母大小写全排列

image.png

🍔思路

我们可以看到我们有三种选择
1.如果是大写则转换为小写
2.如果是小写则转换为大写
3.不进行转换

🍟代码

class Solution:
    def letterCasePermutation(self, s: str) -> List[str]:
        res = []
        def dfs(idx, n, s:str):
            if idx == n:
                res.append(s)
                return
            if s[idx].islower():
                dfs(idx + 1, n, s[:idx] + chr(ord(s[idx]) - 32) + s[idx + 1:])
            if s[idx].isupper():
                dfs(idx + 1, n, s[:idx] + chr(ord(s[idx]) + 32) + s[idx + 1:])
            dfs(idx + 1, n, s)
        dfs(0, len(s), s)
        return res

image.gif

image.png

相关文章
|
23天前
|
算法 容器
【算法】——双指针算法合集(力扣)
移动零,复写零,快乐数,盛最多水的容器,有效三角形的个数,和为s的两个数(查找总价格为目标值的两个商品 ),三数之和,四数之和
|
2月前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
2月前
|
机器学习/深度学习 算法 Python
机器学习入门:理解并实现K-近邻算法
机器学习入门:理解并实现K-近邻算法
45 0
|
3月前
|
算法
每日一道算法题(Leetcode 20)
每日一道算法题(Leetcode 20)
40 2
|
3月前
|
算法
【链表】算法题(二) ----- 力扣/牛客
【链表】算法题(二) ----- 力扣/牛客
|
3月前
|
算法 数据挖掘
【栈和队列】算法题 ---- 力扣(二)
【栈和队列】算法题 ---- 力扣
|
3月前
|
存储 算法
【栈和队列】算法题 ---- 力扣(一)
【栈和队列】算法题 ---- 力扣
|
3月前
|
机器学习/深度学习 算法 大数据
机器学习入门:梯度下降算法(下)
机器学习入门:梯度下降算法(下)
|
3月前
|
算法
【链表】算法题(一) ----- 力扣 / 牛客
【链表】算法题(一) ----- 力扣 / 牛客
|
3月前
|
算法
【顺序表】算法题 --- 力扣
【顺序表】算法题 --- 力扣