描述
输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
思路:把int型转换成string型,如果a+b<b+a,那么a小于b,所以最小数是ab。
创建一个全局变量compare,定义两个string型的字符串,temp1和temp2,让temp1等于字符串a+字符串b,temp2等于字符串b+字符串a,然后返回temp1小于temp2.
通过sort进行排序,对numbers遍历,之后得出的结果就是最小数字。
class Solution {
public:
static bool compare(int a,int b)
{
string temp1=to_string(a)+to_string(b);
string temp2=to_string(b)+to_string(a);
return temp1<temp2;
}
string PrintMinNumber(vector<int> numbers) {
sort(numbers.begin(),numbers.end(),compare);
string ret="";
for(int num:numbers)
{
ret+=to_string(num);
}
return ret;
}
};</int>