题目:
给出集合
[1,2,3,...,n],其所有元素共有n!种排列。按大小顺序列出所有排列情况,并一一标记,当
n = 3时, 所有排列如下:
"123""132""213""231""312""321"给定
n和k,返回第k个排列。来源:力扣(LeetCode)
链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台
示例:
示例 1:
输入:n = 3, k = 3
输出:"213"
示例 2:
输入:n = 4, k = 9
输出:"2314"
示例 3:
输入:n = 3, k = 1
输出:"123"
解法:
使用itertools库的permutations函数。
知识点:
1.str.join(item )**:**str表示字符串,item表示一个成员,注意括号里必须只能有一个成员。将字符串item中的每个成员以字符str分隔开再拼接成一个字符串。
代码:
pythonfrom itertools import permutations class Solution: def getPermutation(self, n: int, k: int) -> str: return ''.join(map(str, list(permutations([item + 1 for item in range(n)]))[k - 1]))
力扣:60. 排列序列(Python3)
恽劼恒2023-08-12 22:01
相关推荐
灵感__idea2 小时前
Hello 算法:贪心的世界知行合一。。。2 小时前
Python--04--数据容器(总结)架构师老Y2 小时前
008、容器化部署:Docker与Python应用打包澈2073 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解lifewange3 小时前
pytest-类中测试方法、多文件批量执行ambition202423 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程pluvium273 小时前
记对 xonsh shell 的使用, 脚本编写, 迁移及调优cmpxr_3 小时前
【C】原码和补码以及环形坐标取模算法qiqsevenqiqiqiqi3 小时前
前缀和差分代码旅人ing3 小时前
链表算法刷题指南