【 声明:版权所有,转载请标明出处,请勿用于商业用途。 联系信箱:libin493073668@sina.com】
题目描述
输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
思路
我们知道,要使得拼接起来得数字最小,将其转换成字符串之后,要求便是使得其拼接之后的字典序最小,所以我们可以将数字转换成字符串之后再对其进行排序,排序的要求自然是要满足拼接最小的条件,对于任意两个串s1,s2而言,满足s1+s2<s2+s1
class Solution { public: string PrintMinNumber(vector<int> num) { string ans = ""; int len = num.size(); if(len==0) return ans; vector<string> nums(len); for(int i = 0; i<len; i++) nums[i] = to_string(num[i]); sort(nums.begin(),nums.end(),cmp); for(int i = 0; i<len; i++) ans+=nums[i]; return ans; } static int cmp(const string &s1,const string &s2) { return s1+s2<s2+s1; } };
版权声明:本文为博主原创文章,如果转载,请注明出处
原文地址:http://blog.csdn.net/libin1105/article/details/48391541