剑指offer系列58---把数组排成最小的数

【题目】输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。
* 例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
【思路】1 首先将整数数组转化成字符串数组str;
    2 写一个定制排序comparator,对str进行排序。排序后得到的结果321,32,3(<)
      排序规则:ab<ba a<b;
            ab>ba a>b;
            ab=ba a=b
    3 得到排序后结果。

****定制排序: int compare(T o1, T o2) :比较用来排序的两个参数。根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数。

 1 package com.exe11.offer;
 2
 3 import java.util.Arrays;
 4 import java.util.Comparator;
 5
 6 /**
 7  * 【题目】输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。
 8  *            例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
 9  * 【思路】1 首先将整数数组转化成字符串数组str;
10  *           2 写一个定制排序comparator,对str进行排序。排序后得到的结果321,32,3(<)
11  *             排序规则:ab<ba  a<b;
12  *                   ab>ba  a>b;
13  *                   ab=ba  a=b
14  *        3 得到排序后结果。
15  *
16  * @author WGS
17  *
18  */
19 public class PrintMinNumberofArray {
20     public String PrintMinNumber(int [] numbers) {
21         if(numbers==null ||numbers.length<=0)
22             return null;
23
24         StringBuilder sb=new StringBuilder();
25         String[] str=new String[numbers.length];
26         //1 转换
27         for(int i=0;i<numbers.length;i++){
28             str[i]=numbers[i]+"";
29         }
30         //2 写一个定制排序
31         Comparator com=new Comparator<String>(){
32             @Override
33             public int compare(String o1, String o2) {
34                 return (o1+o2).compareTo(o2+o1);
35             }
36         };
37         //3 对str进行排序
38         Arrays.sort(str, com);
39         //4 得到排序后的数字
40         for(int i=0;i<str.length;i++){
41             sb.append(str[i]);
42         }
43         return sb.toString();
44     }
45
46     public static void main(String[] args) {
47         PrintMinNumberofArray p=new PrintMinNumberofArray();
48         //int[] nums=new int[]{3,32,321};
49         int[] nums=new int[]{1,12,23,311};
50         String s=p.PrintMinNumber(nums);
51         System.out.println(s);
52     }
53 }
时间: 2024-11-09 22:50:38

剑指offer系列58---把数组排成最小的数的相关文章

剑指offer系列——32.把数组排成最小的数

Q:输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323. T: 把数组排序,排序后从第一个值开始,假如有元素a和元素b,若ab > ba 则 a应该处于b之后:若ab < ba 则a应该处于b之前:若ab = ba 则 a = b:解释说明:比如 "3" 和 "31"比较谁先谁后, "331" > &quo

剑指offer系列——6.旋转数组的最小数字

Q:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1. NOTE:给出的所有元素都大于0,若数组大小为0,请返回0. C:时间限制:C/C++ 3秒,其他语言6秒 空间限制:C/C++ 32M,其他语言64M A: int minNumberInRotateArray(vector<int> rotateArray) { if (

剑指offer java -查找旋转数组的最小数字

/** * Created by wqc on 2017/7/18. * 查找旋转数组的最小数字 * 把一个数组最开始的若干个元素搬到数组的末尾,称为数组的旋转 * 输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素 * 如:3,4,5,1,2 为1,2,3,4,5的一个旋转,最小值为1 */public class Problem8_findMinNumber { public Integer findMinNum(int[] array) { if(array == null) { r

剑指offer编程-旋转数组的最小数字

题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1. NOTE:给出的所有元素都大于0,若数组大小为0,请返回0. 思路: 1.顺序查找 O(n):从前往后,找到当前位置数比它前面的数小的数,返回该数. 2.二分查找 O(logn):每次缩小一半. 特殊情况:!!! 左边的情况最小数在 mid=(p1+p2)/2 左边,右边

剑指offer源码-旋转数组的最小数字

题目1386:旋转数组的最小数字 时间限制:1 秒内存限制:32 兆特殊判题:否提交:5659解决:1273 题目描述: 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转.输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素.例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1. 输入: 输入可能包含多个测试样例,对于每个测试案例, 输入的第一行为一个整数n(1<= n<=1000000):代表旋转数组的元素个数. 输入的第二行包括n个整数,

剑指offer系列源码-数组中只出现一次的数字

题目1351:数组中只出现一次的数字 时间限制:1 秒内存限制:32 兆特殊判题:否提交:2582解决:758 题目描述: 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字. 输入: 每个测试案例包括两行: 第一行包含一个整数n,表示数组大小.2<=n <= 10^6. 第二行包含n个整数,表示数组元素,元素均为int. 输出: 对应每个测试案例,输出数组中只出现一次的两个数.输出的数字从小到大的顺序. 样例输入: 8 2 4 3 6 3 2 5 5

剑指offer系列源码-数组中的逆序对

题目1348:数组中的逆序对 时间限制:1 秒内存限制:32 兆特殊判题:否提交:2133解决:500 题目描述: 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数. 输入: 每个测试案例包括两行: 第一行包含一个整数n,表示数组中的元素个数.其中1 <= n <= 10^5. 第二行包含n个整数,每个数组均为int类型. 输出: 对应每个测试案例,输出一个整数,表示数组中的逆序对的总数. 样例输入: 4 7 5 6 4

剑指offer系列源码-数组中出现次数超过一半的数字

题目1370:数组中出现次数超过一半的数字 时间限制:1 秒内存限制:32 兆特殊判题:否提交:2844解决:846 题目描述: 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2. 输入: 每个测试案例包括2行: 第一行输入一个整数n(1<=n<=100000),表示数组中元素的个数. 第二行输入n个整数,表示数组中的每个元素,这n个整数的范围是[1,10

剑指offer系列——二维数组中,每行从左到右递增,每列从上到下递增,设计一个算法,找其中的一个数

题目:二维数组中,每行从左到右递增,每列从上到下递增,设计一个算法,找其中的一个数 分析: 二维数组这里把它看作一个矩形结构,如图所示: 1 2 8 9 2 4 9 12 4 7 10 13 6 8 11 15 在做这道题的时候我最先考虑的是每次比较对角线上的元素可能可以取得较好的效果, 以查找9为例, 从1(0,0)开始,1<10,可以得出结论,10在1的右侧或下侧: 1 2 8 9 2 4 9 12 4 7 10 13 6 8 11 15 然后看4(1,1),4<9, 1 2 8 9 2

剑指Offer对答如流系列 - 把数组排成最小的数

面试题45:把数组排成最小的数 题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输入数组{3, 32, 321},则打印出这3个数字能排成的最小数字321323. 问题分析 之前我们做过字符全排列的习题 剑指Offer对答如流系列 - 字符串的排列,但是将算法思想应用到这一题的话,效果不好,求出所有的组合,再计算出组合的最小值,这效率该多低啊. 我们还要进一步探究,看看有没有不错的规律,供我们使用. 因为数字拼接后的长度一样,拼接后的结果