把数组排成最小的数

题目描述

输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{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函数对于不同的数据选择不同的排序方法。大概包括快速排序,插入排序和堆排序。比如给一个数据量较大的数组排序,开始采用快速排序,分段递归,分段之后每一段的数据量达到一个较小值后它就不继续往下递归,而是选择插入排序,如果递归的太深,他会选择推排序。

posted @ 2018-06-06 20:52  Lune-Qiu  阅读(647)  评论(0编辑  收藏  举报