《剑指offer》把数组排成最小的数

【 声明:版权所有,转载请标明出处,请勿用于商业用途。 联系信箱:libin493073668@sina.com】

题目链接:?rp=2&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

题目描述输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{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;}};

版权声明:本文为博主原创文章,如果转载,请注明出处

愚者用肉体监视心灵,智者用心灵监视肉体

《剑指offer》把数组排成最小的数

相关文章:

你感兴趣的文章:

标签云: