//输入一个非负整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。 
//
// 
//
// 示例 1: 
//
// 输入: [10,2]
//输出: "102" 
//
// 示例 2: 
//
// 输入: [3,30,34,5,9]
//输出: "3033459" 
//
// 
//
// 提示: 
//
// 
// 0 < nums.length <= 100 
// 
//
// 说明: 
//
// 
// 输出结果可能非常大,所以你需要返回一个字符串而不是整数 
// 拼接起来的数字可能会有前导 0,最后结果不需要去掉前导 0 
// 
// Related Topics 排序 
// 👍 158 👎 0

/*
* 剑指 Offer 45 把数组排成最小的数
* 2021-02-18 11:42:05
* @author oxygenbytes
*/ 
#include "leetcode.h" 
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public:
    string minNumber(vector<int>& nums) {
        sort(nums.begin(), nums.end(), cmp);
        string res;
        for(auto x : nums) res += to_string(x);
        return res;
    }
    static bool cmp(int a, int b){
        auto as = to_string(a), bs = to_string(b);
        return as + bs < bs + as;
    }
};
//leetcode submit region end(Prohibit modification and deletion)