题目描述
输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
代码:
static bool cmp(int a,int b) { string A = to_string(a) + to_string(b); string B = to_string(b) + to_string(a); return A < B; } string PrintMinNumber(vector<int> numbers) { sort(numbers.begin(),numbers.end(),cmp); string str = ""; for(int i = 0; i < numbers.size();i++) { str += to_string(numbers[i]); } return str; }
对于sort函数:sort函数对于不同的数据选择不同的排序方法。大概包括快速排序,插入排序和堆排序。比如给一个数据量较大的数组排序,开始采用快速排序,分段递归,分段之后每一段的数据量达到一个较小值后它就不继续往下递归,而是选择插入排序,如果递归的太深,他会选择推排序。