每天一道剑指offer-把数组排成最小的数

2018-12-31  本文已影响0人  程序员乔戈里

前言

今天的题目
每天的题目见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;
   }
}

结束语

作者乔戈里亲历2019秋招,哈工大计算机本硕,百度java工程师,欢迎大家关注我的微信公众号:程序员乔戈里,公众号有3T编程资源,以及我和我朋友(百度C++工程师)在秋招期间整理的近200M的面试必考的java与C++面经,并有每天一道leetcode打卡群与技术交流群,欢迎关注。

上一篇 下一篇

猜你喜欢

热点阅读