当前位置:首页 > 未命名 > 正文内容

最少交换次数

淙嶙5年前 (2020-07-22)未命名1308

描述


给出一个无序数列,每次只能交换相邻两个元素,求将原数列变成递增数列的最少交换次数。
如:数列:2,3,1,交换3和1后变成:2,1,3;交换1和2之后变成:1,2,3。总共交换2次。


输入


逗号隔开的正整数数列


输出


正整数


输入样例

2,3,1

输出样例

2

< pre class="brush:java;toolbar:false">private static String solution(String line) {     // 在此处理单行数据    String[] a = line.split(","); List list = new LinkedList(); for(int i =0;i<a.length;i++){ list.add(Integer.parseInt(a[i])); } int count = list.size() -1; int changeCount = 0; int maxIndex = 0; while(count-- > 0){ maxIndex = 0; for(int j= 1;j<list.size();j++){ if(list.get(maxIndex) < list.get(j)){ maxIndex =  j; } } changeCount += list.size() -1 - maxIndex; list.remove(maxIndex); }    return String.valueOf(changeCount); }

相关文章

EXPLAIN 命令详解

EXPLAIN 命令详解

在工作中,我们用于捕捉性能问题最常用的就是打开慢查询,定位执行效率差的SQL,那么当我们定位到一个SQL以后还不算完事,我们还需要知道该SQL的执行计划,比如是全表扫描,还是索引扫描,这些都需要...

说一说Java的Unsafe类

说一说Java的Unsafe类

最近在看Java并发包的源码,发现了神奇的Unsafe类,仔细研究了一下,在这里跟大家分享一下。Unsafe类是在sun.misc包下,不属于Java标准。但是很多Java的基础类库,包括一些被广泛使...

爬楼梯

爬楼梯

描述 在你面前有一个n阶的楼梯,你一步只能上1阶或2阶。请问计算出你可以采用多少种不同的方式爬完这个楼梯。 输入 一个正整数,表示这个楼梯一共有多少阶 输出 一个正整数,...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。