题目:
输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
思路:
int全部转换成string 通过自定义如下比较函数排序,然后输出
bool my_compare(string str1, string str2)
{
string str3 = str1 + str2;
string str4 = str2 + str1;
return str3 < str4;
}
代码:
bool my_compare(string str1, string str2)
{
string str3 = str1 + str2;
string str4 = str2 + str1;
return str3 < str4;
}
template<typename T> string toString(const T& t)
{
ostringstream oss;
oss<<t;
return oss.str();
}
class Solution {
public:
string PrintMinNumber(vector<int> numbers)
{
vector<string> num;
num.resize(numbers.size());
for(int i=0; i<numbers.size(); i++)
{
num.push_back(toString(numbers[i]));
}
sort(num.begin(), num.end(), my_compare);
string res;
for(int i=0; i<num.size(); i++)
{
res += num[i];
}
return res;
}
};