链家数组排序最小交换次数解法?

提交不了也不知道对不对,你们是怎么做的
全部评论
http://www.dewen.net.cn/q/7967 直接推公式
点赞 回复 分享
发布于 2017-08-19 22:01
我怎么没这个题 你说的是去重排序的吗 如果是那个题 我用了TreeSet。。。
点赞 回复 分享
发布于 2017-08-19 21:08
插入排序,统计次数
点赞 回复 分享
发布于 2017-08-19 21:10
过了67%
点赞 回复 分享
发布于 2017-08-19 21:17
直接放到set容器,100%。。 哈哈哈
点赞 回复 分享
发布于 2017-08-19 21:21
treeset
点赞 回复 分享
发布于 2017-08-19 21:28
最后怎么输出啊
点赞 回复 分享
发布于 2017-08-19 21:30
//89%,不知道哪里有坑。。。 public static void main(String args[]){ Scanner cin = new Scanner(System.in); int n = cin.nextInt(); int[] array = new int[n]; int a = 0,b = 0,result = 0; for(int i = 0 ; i < n ; ++i){ array[i] = cin.nextInt(); if(array[i] == 1) a++; else if(array[i] == 2) b++; } for(int i = 0 ; i < a ; ++i){ if(array[i] != 1) result++; } for(int i = a ; i < a + b ; ++i){ if(array[i] == 3) result++; } System.out.println(result); }
点赞 回复 分享
发布于 2017-08-19 21:36
一趟3路快排,稍微修改一下就行。
点赞 回复 分享
发布于 2017-08-19 21:46
暴力做的,后来写完的,一开始只能过56,后来改了下,也不知道能不能过全部 public class Lianjia3 { private static boolean isTrue(int[] verify,int[] data, int n){ for (int i=0;i<n;++i){ if (verify[i]!=data[i]){ return false; } } return true; } private static void swap(int i,int j,int[] data){ int t=data[i]; data[i]=data[j]; data[j]=t; } private static int ans=Integer.MAX_VALUE; public static void solve(int index,int[] verify,int[] data,int n,int cur){ if (isTrue(verify, data, n)){ ans=Math.min(ans, cur); return; } if (verify[index]==data[index]){ solve(index+1, verify, data, n, cur); return; } int id=-1; for (int j=index+1;j<n;++j){ if(data[j]==verify[index] && verify[j]==data[index]){ id=j; break; } } if(id!=-1){ swap(index, id, data); solve(index+1, verify, data, n, cur+1); } if (id==-1){ for (int j=index+1;j<n;++j){ if(data[j]==verify[index] && verify[j]!=data[j]){ id=j; swap(index, j, data); solve(index+1, verify, data, n, cur+1); swap(index, j, data); } } } } public static void main(String[] args) { // TODO Auto-generated method stub Scanner in=new Scanner(System.in); int n=in.nextInt(); int[] data=new int[n]; int oneCount=0; int twoCount=0; int threeCount=0; for (int i=0;i<n;++i){ data[i]=in.nextInt(); if (data[i]==1){ oneCount++; }else if (data[i]==2){ twoCount++; }else{ threeCount++; } } int[] verify=new int[n]; int i=0; for (int j=0;j<oneCount;++j){ verify[i++]=1; } for (int j=0;j<twoCount;++j){ verify[i++]=2; } for (int j=0;j<threeCount;++j){ verify[i++]=3; } solve(0,verify, data, n, 0); System.out.println(ans); in.close(); } }
点赞 回复 分享
发布于 2017-08-19 21:47
1中2和2中的1交换,1中的3和3中的1交换,2中的3和3中的2交换,每一次交换count+1; 剩下的就是1 2 3 互换的 ,每一次count+2
点赞 回复 分享
发布于 2017-08-20 10:00
import java.util.Scanner; public class Solution { /** * @param args */ static int sum = 0; public static void main(String[] args) { // TODO Auto-generated method stub Scanner in = new Scanner(System.in); while (in.hasNext()) { int n = in.nextInt(); int[] arr = new int[n]; for (int i = 0; i < n; i++) { arr[i] = in.nextInt(); } int lo = 0; int hi = n - 1; quick(arr, lo, hi); System.out.println(sum); } } public static void quick(int[] arr, int lo, int hi) { if (hi <= lo) { return; } int lt = lo; int i = lo + 1; int gt = hi; int tmp = arr[lo]; while (i <= gt) { if (arr[i] < tmp) { swap(arr, lt++, i++); } else if (arr[i] > tmp) { swap(arr, i, gt--); } else { i++; } } quick(arr, lo, lt - 1); quick(arr, gt + 1, hi); } public static void swap(int[] a, int i, int j) { if (a[i] != a[j]) sum++; int tmp = a[i]; a[i] = a[j]; a[j] = tmp; } } 三向切分快排,不知道好不好使
点赞 回复 分享
发布于 2017-08-20 10:39
先一次遍历统计1的个数,2的个数和3的个数。然后统计本来应该是1的位置然而不是1的个数notone,本来应该是2的位置然而是3的个数cnt23,本来应该是3的位置是2的个数cnt32。结果为notone+max(can23,cnt32)。
点赞 回复 分享
发布于 2017-08-20 10:53

相关推荐

2024-12-27 23:45
已编辑
三江学院 Java
程序员牛肉:死局。学历+无实习+项目比较简单一点。基本就代表失业了。 尤其是项目,功能点实在是太假了。而且提问点也很少。第一个项目中的使用jwt和threadlocal也可以作为亮点写出来嘛?第二个项目中的“后端使用restful风格”,“前端采用vue.JS”,“使用redis”也可以作为亮点嘛? 项目实在是太简单了,基本就是1+1=2的水平。而你目标投递的肯定也是小厂,可小厂哪里有什么培养制度,由于成本的问题,人家更希望你来能直接干活,所以你投小厂也很难投。基本就是死局,也不一定非要走后端这条路。可以再学一学后端之后走测试或者前端。 除此之外,不要相信任何付费改简历的。你这份简历没有改的必要了,先沉淀沉淀
点赞 评论 收藏
分享
已经烂了:算法去制造业最少也要211,双非搞算法就是死路一条。至少我在的部门,算法工程师最低都是211毕业的,而且岗位极少。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务