首页 > 代码库 > 面试题:一个整型数组中各元素排列组合得到的最大的一个数 ,比如,1,3,9,11,23,233,911 要得到:9,911,3,233,23,11,1
面试题:一个整型数组中各元素排列组合得到的最大的一个数 ,比如,1,3,9,11,23,233,911 要得到:9,911,3,233,23,11,1
package com.alibaba.interview;import java.util.Random;/** * @Author: weblee * @Email: likaiweb@163.com * @Blog: http://www.cnblogs.com/lkzf/ * @Time: 2014年10月25日下午2:58:39 * ************* function description *************** *一个整型数组中各元素排列组合得到的最大的一个数 ,比如,1,3,9,11,23,233,911 要得到:9,911,3,233,23,11,1 **************************************************** * *solution: * ①确定该数组array中数字最长的数字,得到最长len * ②new 等长的数组doArray,存放处理之后的原数组(角标pos与值对应关系不变),how to 处理,将所有的数追加末尾数字c变为等长(len), * ③对doArray 快速排序,同步交换 doArray、array的 角标对应的数字 swap(int[] doArray, int i, int j, int[] array) * * 时间O(nlog(n)),空间O(n) */public class FirstSort { public static void sort(int[] array) { int max = 0; for (int i = 1; i < array.length; i++) { if (max < array[i]) max = array[i]; } int len = (max + "").length(); int[] doArray = new int[array.length]; for (int i = 0; i < array.length; i++) { doArray[i] = doNum(array[i], len); } quickSort(doArray, 0, doArray.length - 1, array); } private static Random rand = new Random(); /** * 快速排序法 */ private static void quickSort(int[] a, int p, int r, int[] num) { while (p < r) { int q = randomPartition(a, p, r, num); quickSort(a, p, q - 1, num); p++; } } private static int partition(int[] a, int p, int r, int[] num) { int x = a[p]; int i = p - 1; for (int j = p; j <= r; j++) { if (a[j] >= x) { i++; swap(a, i, j, num); } } swap(a, p, i, num); return i; } private static int randomPartition(int[] a, int p, int r, int[] num) { int i = rand.nextInt(r - p) + p; swap(a, p, i, num); return partition(a, p, r, num); } private static void swap(int[] a, int i, int j, int[] num) { int temp = a[i]; a[i] = a[j]; a[j] = temp; // temp = num[i]; num[i] = num[j]; num[j] = temp; } static int doNum(int num, int len) { StringBuffer buffer = new StringBuffer(num + ""); char c = buffer.charAt(buffer.length() - 1); int bit = buffer.length(); while (bit != len) { buffer.append(c); bit++; } return Integer.parseInt(buffer.toString()); } // 输出方法,因为sort是按照从小到大的进行排序的,所以要Display方法处理一下 public static void display(int[] L) { for (int i : L) { System.out.print(i + "\t"); } } /** * @param args */ public static void main(String[] args) { int[] arr = { 1, 3, 9, 11, 23, 233, 911 }; sort(arr); display(arr); }}
面试题:一个整型数组中各元素排列组合得到的最大的一个数 ,比如,1,3,9,11,23,233,911 要得到:9,911,3,233,23,11,1
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。