把数组排成最小的数

2020-05-13  本文已影响0人  su945

题目描述

输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。

问题分析

根据上述规则,我们需要先将数字转换成字符串再进行比较,因为需要串起来进行比较。比较完之后,按顺序输出即可。

解题思路1

class Solution {
public:
    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) {
        if (numbers.empty())
        {
            return "";
        }
        sort(numbers.begin(),numbers.end(),cmp);
        string maxStr ;
        for (int i = 0; i < numbers.size(); ++i)
        {
            maxStr += to_string(numbers[i]);
        }
        return maxStr;
    }
};
上一篇下一篇

猜你喜欢

热点阅读