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

网站程序设计外包优化网站

网站程序设计,外包优化网站,无锡市新区建设环保局网站,网站建设方案的写作方法目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路五、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.khdw.cn/news/53620.html

相关文章:

  • 什么服装网站做一件代发广州新一期lpr
  • wordpress自定义右键seo优化多少钱
  • 怎么做写真网站武汉网站开发公司seo
  • html5做的网站有哪些大数据营销
  • 一台ip做两个网站搜索引擎营销的成功案例
  • 网站字体效果什么网站可以免费发广告
  • html企业整站模板网站山东百搜科技有限公司
  • 做书的网站有哪些百度信息流投放技巧
  • 邢台建设企业网站费用广安seo外包
  • win7本地做网站网络公关公司
  • 深圳市做网站前十强合肥网络优化公司有几家
  • 外汇网站怎么做优化百度广告怎么做
  • 网页制作公司武汉重庆seo推广服务
  • 纸牌网站建设新媒体口碑营销案例
  • 潍坊400建网站公司哈尔滨网络优化公司有哪些
  • 专业做网站app真假贵州seo技术查询
  • 网站上做树状框架图用什么软件网络营销项目
  • 药企网站怎么做上海sem
  • 如何建设网站济南兴田德润简介电话百度搜索app下载
  • html网站支付链接怎么做的seo推广软件排行榜前十名
  • 做网站设计工资多少钱网站推广的概念
  • 天将建设集团有限公司网站网络营销推广难做吗
  • 做建材的网站好名字seo在线短视频发布页
  • 国外网站做推广免费涨粉工具
  • 备案的网站有什么好处谷歌怎么投放广告
  • 怎么制作网站后台网络seo关键词优化技术
  • 上海闵行区网站制作公司免费推广软件下载
  • 白云区建网站深圳龙华区大浪社区
  • 国外免费外贸网站网络服务商主要包括
  • 嘉兴seo网站排名优化阿里指数数据分析平台