python【第k个排列】给定参数n,从1到n会有n个整数:1,2,3,...,n,这n个数字共有n!种排列。

本文介绍了如何使用Python编程语言实现两种方法来获取给定整数n和k时的第k个排列,包括利用itertools库和递归的方式,适合n≤9且1≤k≤n!的场景。通过实例演示和代码实现,帮助读者理解排列问题的解决思路。
摘要由CSDN通过智能技术生成

题目

【第k个排列】给定参数n,从1到n会有n个整数:1,2,3,...,n,这n个数字共有n!种排列。
按大小顺序升序列出所有排列情况,并一一标记,当n=3时,所有排列如下:
"123"
"132"
"213"
"231"
"312"
"321"
给定n和k,返回第k个排列。
输入描述:
输入两行,第一行为n,第二行为k,给定n的范围是[1,9],给定k的范围是[1,n!]。

输出描述:
输出排在第k位置的数字。

示例1:
输入:
3
3

输出:
213

代码实现方式一

import itertools
def getPernumtation(n,k):
    list1 = range(1,n+1)
    templist = list(itertools.permutations(list1))
    for i,temp in enumerate(templist):
        if k == i+1:
            return ''.join([str(j) for j in temp])
n = input()
k = input()
print(getPernumtation(int(n),int(k)))

参考链接

https://blog.csdn.net/yuzipeng/article/details/102468691

代码实现方式二

def getPermutation(n,k):
	def get_n(n):
		res = 1
		for i in range(1,n+1):
			res *= i
		return res
	ret,nums = '',list(map(str,list(range(1,n+1))))
	for i in range(n,0,-1):
		res = get_n(i-1)
		index = (k-1)//res
		ret += nums.pop(index)
		k -= res*index
	return ret
n = input()
k = input()
print(getPermutation(int(n),int(k)))

参考链接

https://blog.csdn.net/qq_43109561/article/details/90341828

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wellnw

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值