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

第k个排列 - 华为OD统一考试(E卷)

2024华为OD机试(E卷+D卷+C卷)最新题库【超值优惠】Java/Python/C++合集

华为od机试

题目描述

给定参数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说明:
3的排列有123 132 213...,那么第3位置的为213

示例2

输入:
2
2输出:
21说明:
2的排列有12 21,那么第2位置的为21

题解

这道题属于排列组合问题,需要找到第 k 个排列。给定数字 n,有 n! 种排列。通过 数学方法 来求解,我们可以避免生成所有排列,直接通过数学推理一步步缩小范围,找到目标排列。

思路

  1. 数学推导
    • 每个位置的元素可以通过判断当前是第几组排列来决定。对于排列的第一位,有 n 种选择,而剩下的 n-1 位对应的排列数为 (n-1)!
    • 比如 n=3,则有 3!=6 种排列,其中每两组排列会以 1 开头、2 开头、或者 3 开头。所以第一个位置的数字可以通过 k 来确定,依次缩小范围直到找出第 k 个排列。
  2. 逐步计算
    • 计算 (n-1)!,确定第一个数字的范围;
    • 更新 k 的值,并继续计算下一个位置的数字,直到生成完整排列。
  3. 关键技巧
    • 用一个数字列表存储所有可以选择的数字;
    • 根据 k 来选择当前的数字,并将其从候选列表中移除;
    • 每次计算第 i 位时,将 k 减去已经完成的所有组数。

时间复杂度

  • 由于每次计算需要根据 (n-1)! 来确定当前数字,时间复杂度为 O(n)

Java

import java.util.*;
/*** @author code5bug*/
public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n = sc.nextInt();int k = sc.nextInt();System.out.println(getPermutation(n, k));}public static String getPermutation(int n, int k) {// 初始化可选数字列表List<Integer> nums = new ArrayList<>();for (int i = 1; i <= n; i++) {nums.add(i);}StringBuilder result = new StringBuilder();k--;  // 转换为从 0 开始计数// 逐位确定排列int fact = 1;for (int i = 1; i < n; i++) {fact *= i;  // 计算 (n-1)!}for (int i = n; i > 0; i--) {// 确定当前位的索引int index = k / fact;result.append(nums.remove(index));// 更新 k 的值k %= fact;if (i > 1) {fact /= (i - 1);  // 计算新的 (i-2)!}}return result.toString();}
}

Python

import mathdef get_permutation(n, k):# 初始化可选数字列表nums = [str(i) for i in range(1, n + 1)]# 结果数组result = []# 将 k 转为从 0 开始计数k -= 1# 逐位确定排列for i in range(n, 0, -1):# 计算 (i-1)! 的值fact = math.factorial(i - 1)# 选择当前位的数字index = k // factresult.append(nums.pop(index))# 更新 k 的值k %= fact# 返回结果字符串return ''.join(result)# 输入处理
if __name__ == "__main__":n = int(input())k = int(input())# 输出第 k 个排列print(get_permutation(n, k))

C++

#include <iostream>
#include <vector>
#include <algorithm>using namespace std;string getPermutation(int n, int k) {// 初始化可选数字列表vector<int> nums;for (int i = 1; i <= n; i++) {nums.push_back(i);}string result;k--;  // 转换为从 0 开始计数// 逐位确定排列int fact = 1;for (int i = 1; i < n; i++) {fact *= i;  // 计算 (n-1)!}for (int i = n; i > 0; i--) {// 确定当前位的索引int index = k / fact;result += to_string(nums[index]);nums.erase(nums.begin() + index);  // 从列表中移除该数字// 更新 k 的值k %= fact;if (i > 1) {fact /= (i - 1);  // 计算新的 (i-2)!}}return result;
}int main() {int n, k;cin >> n >> k;cout << getPermutation(n, k) << endl;return 0;
}

相关练习题

题号题目难易
60. 排列序列60. 排列序列困难

整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Java学习路线
  • 51单片机 - DS18B20实验1-读取温度
  • 浏览器指纹修改指南2024 - CommandLine(一)
  • 速盾:h5小游戏需要开cdn吗?
  • # windows 运行框输入mrt提示错误:Windows 找不到文件‘mrt‘。请确定文件名是否正确后,再试一次
  • 腾讯百度阿里华为常见算法面试题TOP100(3):链表、栈、特殊技巧
  • 基于C++实现(MFC)职工工作量统计系统
  • Android OkHttp源码分析(一):为什么OkHttp的请求速度很快?为什么可以高扩展?为什么可以高并发
  • Python 集成快递物流 API 助力订单追踪:轻松实现物流可视化
  • 如何让Windows控制台窗口不接受鼠标点击(禁用鼠标输入)
  • 面试真题-TCP的三次握手
  • 线性基速通
  • 【STM32】独立看门狗(IWDG)原理详解及编程实践(上)
  • OpenCV-模板匹配多个目标
  • 【Java】网络编程:TCP_IP协议详解(IP协议数据报文及如何解决IPv4不够的状况)
  • 【comparator, comparable】小总结
  • CoolViewPager:即刻刷新,自定义边缘效果颜色,双向自动循环,内置垂直切换效果,想要的都在这里...
  • Docker: 容器互访的三种方式
  • Java 网络编程(2):UDP 的使用
  • Linux后台研发超实用命令总结
  • MyEclipse 8.0 GA 搭建 Struts2 + Spring2 + Hibernate3 (测试)
  • MySQL的数据类型
  • 高程读书笔记 第六章 面向对象程序设计
  • 移动端 h5开发相关内容总结(三)
  • ionic入门之数据绑定显示-1
  • ​补​充​经​纬​恒​润​一​面​
  • ###C语言程序设计-----C语言学习(3)#
  • $nextTick的使用场景介绍
  • (6)设计一个TimeMap
  • (cljs/run-at (JSVM. :browser) 搭建刚好可用的开发环境!)
  • (C语言)二分查找 超详细
  • (ZT)一个美国文科博士的YardLife
  • (动手学习深度学习)第13章 计算机视觉---微调
  • (转)mysql使用Navicat 导出和导入数据库
  • (转)德国人的记事本
  • (转)项目管理杂谈-我所期望的新人
  • (转载)虚函数剖析
  • .aanva
  • .NET C# 配置 Options
  • .NET Core SkiaSharp 替代 System.Drawing.Common 的一些用法
  • .NET 设计模式—简单工厂(Simple Factory Pattern)
  • .NET 中让 Task 支持带超时的异步等待
  • .vue文件怎么使用_我在项目中是这样配置Vue的
  • @selector(..)警告提示
  • @SuppressLint(NewApi)和@TargetApi()的区别
  • @zabbix数据库历史与趋势数据占用优化(mysql存储查询)
  • [ CTF ] WriteUp- 2022年第三届“网鼎杯”网络安全大赛(白虎组)
  • [Android] 240204批量生成联系人,短信,通话记录的APK
  • [asp.net core]project.json(2)
  • [C# WPF] 如何给控件添加边框(Border)?
  • [C# 基础知识系列]专题十六:Linq介绍
  • [C#]C# winform实现imagecaption图像生成描述图文描述生成
  • [C#]winform使用引导APSF和梯度自适应卷积增强夜间雾图像的可见性算法实现夜间雾霾图像的可见度增强
  • [cb]UIGrid+UIStretch的自适应
  • [CSS]CSS 的背景