算法 第25天 回溯2

216 组合总和III

找出所有相加之和为 n 的 k 个数的组合,且满足下列条件:

只使用数字1到9;每个数字 最多使用一次 ;

返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。

python 复制代码
def combineSum3(k:int,n:int)->'ListList[int]'
	result=[]
def backtracking(targetSum,k,currentSum,startIndex,path,result):
	if currentSum>targetSum:
		return
	if len(path)==k:
		if currentSum==targetSum:
			result.append(path[:])
		return 
	for i in range(startIndes,9-(k-len(path))+2):
		currentSum+=i
		path.append(i)
		backtracking(targetSum,k,currentSum,i+1,path,result)
		currentSum-=i
		path.pop()

17 电话号码的字母组合

给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。

给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

思路

根据index获取digits中的一个digit,根据digit作索引找到letterMap对应letters,遍历(取一个letter,递归第二个digit...直到digits全部对应,加入到result中)

python 复制代码
letterMap=['','','abc','def','ghi','jkl','mno','pqrs','tuv','wxyz']
def backtracking(digits,index):
	if index==len(digits):
		result.append(s)
		return 
	digit=int(digits[index])
	letters=letterMap[digit]
	for i in range(len(letters)):
		s+=letters[i]
		backtracking(digits,index+1)
		s=s[:-1]
		
def letterCombinations(digits:'str')->'List[str]':
	result=[]
	s=''
	if len(digits)=0:
		return []
	backtracking(digits,index=0)
	return result
	
  
	
相关推荐
云里雾里!1 分钟前
力扣 268. 缺失数字 ✅ 【位运算(异或)最优解法】深度解析
算法·leetcode
YJlio6 分钟前
PsPing 学习笔记(14.7):一条龙网络体检脚本——连通性、延迟、带宽全都要
开发语言·网络·笔记·python·学习·pdf·php
kaikaile19958 分钟前
ISODATA聚类方法在MATLAB中的实现指南
算法·matlab·聚类
梭七y11 分钟前
【力扣hot100题】(122)回文链表
算法·leetcode·链表
J_liaty12 分钟前
雪花主键(Snowflake ID)算法详解
算法
2401_8414956416 分钟前
【DeepSeek系列】论文《mHC: Manifold-Constrained Hyper-Connections》全流程复现详解(附Python代码)
人工智能·pytorch·python·深度学习·论文复现·deepseek·mhc模型
汤姆yu17 分钟前
基于python大数据的地震数据可视化分析系统
大数据·python·信息可视化
阿蔹22 分钟前
Python-基础语法五-数据可视化、对象、类、多态、继承、封装、抽象类
开发语言·python
tobias.b23 分钟前
408真题-2009-7-数据结构-无向连通图性质
数据结构·算法·408考研·408真题·真题解析
小白学大数据27 分钟前
未来趋势:AI 时代下 python 爬虫技术的发展方向
运维·人工智能·爬虫·python·自动化