每天一道剑指offer-把数组排成最小的数
- 2019 年 10 月 4 日
- 筆記
前言
今天的题目 每天的题目见github(看最新的日期): https://github.com/gzc426 具体的题目可以去牛客网对应专题去找。
题目
每天一道剑指offer-把数组排成最小的数 来源: https://www.nowcoder.com/practice/fe6b651b66ae47d7acce78ffdd9a96c7?tpId=13&tqId=11180&tPage=2&rp=2&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking
题目详述
输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
思路
和昨天的那道题一样,全排列数组中所有的情况,把所有结果存到treeSet里面,然后由于是treeSet是按照从小到大排序的,所有返回第一个结果就行。
题目详解
import java.util.*; public class Solution { public String PrintMinNumber(int [] numbers) { if(numbers.length == 0) return ""; TreeSet<String> set = new TreeSet<>(); PrintMinNumber(numbers,0,set); return set.pollFirst(); } public void PrintMinNumber(int [] numbers,int index,TreeSet<String> set) { if(index == numbers.length-1) { String tempStr = ""; for(int i=0;i<numbers.length;i++) tempStr += String.valueOf(numbers[i]); set.add(tempStr); }else{ for(int i=index;i<numbers.length;i++) { swap(numbers,index,i); PrintMinNumber(numbers,index+1,set); swap(numbers,index,i); } } } public void swap(int [] numbers,int i,int j) { int temp = numbers[i]; numbers[i] = numbers[j]; numbers[j] = temp; } }