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

dw做网站怎么设置页面音乐全网营销推广怎么收费

dw做网站怎么设置页面音乐,全网营销推广怎么收费,网站密码忘记了怎么办,装修公司做推广网站怎么弄目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路五、Java算法源码六、效果展示1、输入2、输出3、说明 华为OD机试 2023B卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试(JAVA)真题(A卷B卷&#…

在这里插入图片描述

目录

    • 专栏导读
    • 一、题目描述
    • 二、输入描述
    • 三、输出描述
    • 四、解题思路
    • 五、Java算法源码
    • 六、效果展示
      • 1、输入
      • 2、输出
      • 3、说明

华为OD机试 2023B卷题库疯狂收录中,刷题点这里

专栏导读

本专栏收录于《华为OD机试(JAVA)真题(A卷+B卷)》。

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

一、题目描述

给定参数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位置的数字。

输入输出说明
3
3
2133的排列有“123”,“132,“213”,“231”,“312”,“321”,第三个就是213

通过n=3进行分析,以1开头、以2开头、以3开头的排列个数各有两个,因为固定开头为1的,则其排列情况就是n=2的排列情况,即有两个23、32。

四、解题思路

  1. 输入两行,第一行为n,第二行为k;
  2. 全排列递归算法,从第一个数开始;
    • 参数分别是需要排列的数组,初始位置,结束位置;
    • 递归结束标识是,初始位置 = 结束位置;
    • 进行数据交换;
    • 全排列递归算法;
    • 数据还原;
  3. 对其升序排序;
  4. 取第k个排列。

五、Java算法源码

package com.guor.od;import java.util.*;public class OdTest01 {private static List<Integer> list = new ArrayList<>();public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n = sc.nextInt();int k = sc.nextInt();int[] arr = new int[n];for (int i = 0; i < n; i++) {arr[i] = i + 1;}// 全排列递归算法,从第一个数开始recursion(arr, 0, n - 1);// 升序排序Collections.sort(list);System.out.println(list.get(k - 1));}/*** 全排列递归算法** @param arr  需要排列的数组* @param start 初始位置* @param end    结束位置*/private static void recursion(int[] arr, int start, int end) {if (start == end) {String str = "";for (int a : arr) {str += a;}list.add(Integer.parseInt(str));} else {for (int i = start; i <= end; i++) {// 交换swap(arr, start, i);// 全排列递归算法recursion(arr, start + 1, end);// 数据还原swap(arr, start, i);}}}/*** 数据交换*/private static void swap(int[] arr, int x, int y) {int temp = arr[x];arr[x] = arr[y];arr[y] = temp;}
}

六、效果展示

1、输入

3
3

2、输出

213

3、说明

3的排列有“123”,“132,“213”,“231”,“312”,“321”,第三个就是213。

在这里插入图片描述


🏆下一篇:华为OD机试 - 荒岛求生 - 栈Stack(Java 2023 B卷 100分)

🏆本文收录于,华为OD机试(JAVA)真题(A卷+B卷)

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述

http://www.yayakq.cn/news/622991/

相关文章:

  • 做电影网站有什么好处和坏处自媒体怎么入门
  • 网站做优化每天一定要更新公司宣传册排版
  • 厦门大型服装商城网站建设seo
  • 什么是网站结构优化国家骨干院校建设网站
  • 建个大型网站要多少钱文章类网站
  • 扬子市建设局网站厦门区块链网站开发
  • 铜山区建设局招投标网站城固网站建设
  • 单页网站仿制教程最新seo网站优化教程
  • 洛阳网站排名长寿网站建设
  • 列表网做优化网站怎么样都网站建设
  • 建设部网站撤销注册资质的都是公职人员吗网站排版怎么做的
  • 给上市公司做网站有什么用wordpress 正在执行维护
  • 济南建网站送400电话wordpress网站演示
  • wordpress网站页脚网页设计与制作教程第四版清华大学出版社
  • 做网站推广要注意的事项h5编辑工具
  • 网站过度优化wordpress注册页面主题
  • 长春建个网站需要多少钱?管网建设网站
  • 杭州网站设计询问蓝韵网络大连市城乡建设档案馆网站
  • 网站移动端试卷网站在线做
  • 怎样做私人网站网页版微信小程序页面入口
  • 网站建设是固定资产吗泉州玖码网络设计
  • 三明市建设局网站厦门建筑人才网
  • 免费推广网站2022重庆忠县网站建设公司推荐
  • 专门做头像的网站单产品网站
  • asp后台怎么加载网站网站首页不收录
  • 网站所有权注册好了域名怎么开始做网站
  • 成都建设项目环境影响登记网站手机百度网盘下载慢怎么解决
  • 桥头仿做网站做网站的技术支持
  • 网站增加聊天靖江有哪些做网站的
  • 做民宿上几家网站好wordpress主题 插件