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

如何建设网站简答题太原网站建设模板

如何建设网站简答题,太原网站建设模板,服务公司发展战略,西安旅游攻略知乎一、全排列(Leetcode 46) 与组合问题不同,排列问题要注意2个特点: 每层都是从0开始搜索而不是startIndex需要used数组记录path里都放了哪些元素 class Solution:def permute(self, nums):result [] # 存储所有的排列self.back…

一、全排列(Leetcode 46)

与组合问题不同,排列问题要注意2个特点:

  • 每层都是从0开始搜索而不是startIndex
  • 需要used数组记录path里都放了哪些元素
class Solution:def permute(self, nums):result = []  # 存储所有的排列self.backtracking(nums, [], [False] * len(nums), result)  # 调用回溯函数开始排列生成return result  # 返回所有排列结果def backtracking(self, nums, path, used, result):# 基准条件:当路径长度等于nums长度时,说明已经生成了一个完整排列if len(path) == len(nums):result.append(path[:])  # 将当前排列添加到结果中return# 遍历每个元素,尝试放入路径中for i in range(len(nums)):# 如果nums[i]已经被使用过,跳过该元素if used[i]:continue# 标记当前元素为已使用used[i] = True# 将当前元素添加到路径中path.append(nums[i])# 递归生成下一个排列self.backtracking(nums, path, used, result)# 回溯:撤销当前选择path.pop()  # 从路径中移除当前元素used[i] = False  # 将当前元素标记为未使用,供后续递归使用

二、全排列II (Leetcode 47)

对于排列问题,树层上去重和树枝上去重,都是可以的,但是树层上去重效率更高!

class Solution:def permuteUnique(self, nums):nums.sort()  # 排序,方便去重result = []  # 存储所有唯一排列self.backtracking(nums, [], [False] * len(nums), result)  # 调用回溯函数return result  # 返回所有排列结果def backtracking(self, nums, path, used, result):# 基准条件:路径长度等于nums长度时,说明生成了一个完整排列if len(path) == len(nums):result.append(path[:])  # 将当前路径的副本加入结果return# 遍历每个元素,尝试加入当前路径for i in range(len(nums)):# 如果当前元素与前一个相同,并且前一个元素未被使用,则跳过,避免重复排列if (i > 0 and nums[i] == nums[i - 1] and not used[i - 1]) or used[i]:continue# 标记当前元素为已使用used[i] = Truepath.append(nums[i])  # 将当前元素加入路径self.backtracking(nums, path, used, result)  # 递归生成下一个排列path.pop()  # 回溯,移除当前元素used[i] = False  # 将当前元素标记为未使用,供后续递归使用

三、重新安排行程(Leetcode 332)

class Solution:def findItinerary(self, tickets: List[List[str]]) -> List[str]:self.adj = {}  # 用于存储每个城市到其他城市的航班# 将航班按目的地字母排序tickets.sort(key=lambda x: x[1])# 构建每个城市的邻接表for u, v in tickets:if u in self.adj:self.adj[u].append(v)else:self.adj[u] = [v]self.result = []  # 存储结果的路径self.dfs("JFK")  # 从JFK出发return self.result[::-1]  # 结果是反向的,返回反转后的路径def dfs(self, s):# 当城市有可用航班时,继续深度优先搜索while s in self.adj and len(self.adj[s]) > 0:v = self.adj[s][0]  # 选择字母顺序最小的目的地self.adj[s].pop(0)  # 移除已使用的航班self.dfs(v)  # 从新的城市继续深度搜索self.result.append(s)  # 记录当前城市

四、N皇后(Leetcode 51)

class Solution:def solveNQueens(self, n: int) -> List[List[str]]:result = []  # 存储最终结果的二维字符串数组,存放所有有效解# 初始化一个棋盘,棋盘是由 n 行字符串组成,每行包含 n 个 '.',表示空位置chessboard = ['.' * n for _ in range(n)]  # 使用 '.' 表示空格self.backtracking(n, 0, chessboard, result)  # 回溯求解,起始行从0开始# 将结果中的每行列表转换成字符串并返回return [[''.join(row) for row in solution] for solution in result]  def backtracking(self, n: int, row: int, chessboard: List[str], result: List[List[str]]) -> None:# Base case: 如果已经放置了 n 个皇后,说明找到了一种解if row == n:result.append(chessboard[:])  # 将当前棋盘布局加入到结果集中return# 对当前行的每一列进行尝试for col in range(n):# 如果当前位置合法,放置皇后并递归处理下一行if self.isValid(row, col, chessboard):# 放置皇后,修改棋盘当前行的列为 'Q'chessboard[row] = chessboard[row][:col] + 'Q' + chessboard[row][col+1:]# 递归处理下一行self.backtracking(n, row + 1, chessboard, result)# 回溯:撤销当前皇后的放置chessboard[row] = chessboard[row][:col] + '.' + chessboard[row][col+1:]def isValid(self, row: int, col: int, chessboard: List[str]) -> bool:# 检查当前列是否已经有皇后for i in range(row):if chessboard[i][col] == 'Q':return False  # 列冲突,返回不合法# 检查 45 度角方向(左上到右下的对角线)是否有皇后i, j = row - 1, col - 1while i >= 0 and j >= 0:if chessboard[i][j] == 'Q':return False  # 45度角冲突,返回不合法i -= 1j -= 1# 检查 135 度角方向(右上到左下的对角线)是否有皇后i, j = row - 1, col + 1while i >= 0 and j < len(chessboard):if chessboard[i][j] == 'Q':return False  # 135度角冲突,返回不合法i -= 1j += 1return True  # 没有冲突,当前位置合法
http://www.dtcms.com/a/420079.html

相关文章:

  • GA论文阅读
  • 网站访客自己做网站设计制作
  • 网站开发外文期刊网沈阳定制网页设计
  • 一个只做百合的网站怎样在安装wordpress
  • dede做的网站被植入广告中国建筑网信息查询
  • fireworks个人网站模板诸暨市建设局官方网站
  • 泰安营销网站建设公司动画设计专业好的学校
  • CKAD-CN 考试知识点分享(19) 创建 Deployment 并指定环境变量
  • 网桥(交换机)地址学习与转发流程案例分析(一文掌握)
  • 高通平台WiFi学习--WLAN PDR 与 PD RAMdump 功能的启用、禁用及相关操作指南
  • ETL调度最佳实践:避免高峰期任务冲突与资源争抢
  • 关于学习英语的前提是培养语感问题
  • 上海做淘宝网站建设音乐相册制作网站
  • 网站备案的幕布是什么来的网站开发外包平台
  • 公司网站设计好北京网站推广技巧
  • pKa预测模型——pKa-predictor
  • 加密货币时代下预测市场的兴起
  • EDA设计利器 Altium Designer 25.8.1 安装与使用学习指南
  • 黄岗住房和城乡建设厅官方网站做计算机题的网站
  • 沈阳优化网站公司wordpress最简洁主题
  • BriLLM: Brain-inspired Large Language Model 文章评论
  • 宿舍网页设计html模板厦门seo公司到1火星
  • 质数判断 查表法和计算法结合提高效率 (不能因式分解)
  • linux配置数据库
  • 深圳模板网站建设哪家好二级域名备案
  • HTTP(web缓存与历史迭代)
  • 公司网站维护费用计哪个科目北京市官网
  • 做业精灵官方网站江苏省建设工程招投标网站
  • 蓝点触控:力觉是机器人“稳不稳、准不准”的关键
  • 从Gemini Robotics看通用机器人的技术路径