首页 > 编程语言 > 详细

解题报告——把数组排成最小的数

时间:2015-08-08 10:33:24      阅读:267      评论:0      收藏:0      [点我收藏+]

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

    思路:首先,看到题目就要想到先把整数转换为字符串,因为结果肯定是一个大数。然后分析这道题目的本质,其实就是要对转换后的字符串进行排序,然后顺序输出即可,至于排序的方式需要自己定义。举个例子,题目中的字符串“3”和“32”,我们对这两个字符串的“大小”进行排序时,如果“3”在前面,则输出结果为“332”,很显然最后结果比“323”要大。因此我们定义排序方式时,不是比较a和b,而且比较ab和ba,如果ab小,则a排在前面,否则b排在前面。因此可以写出代码。

    下面是我自己的代码,一次AC。

   

class Solution {
public:
    static bool compare(const string &str1,const string &str2){
        string s1 = str1 + str2;
        string s2 = str2 + str1;
        return s1<s2;
    }
    string PrintMinNumber(vector<int> numbers) {
        string result;
        if(numbers.size()<=0){
            return result;
        }
        vector<string> strNum;
        for(int i=0;i<numbers.size();++i){
            stringstream ss;
            string s;
            ss << numbers[i];
            ss >> s;
            strNum.push_back(s);
        }
        sort(strNum.begin(),strNum.end(),compare);
         
        for(int i=0;i<numbers.size();++i)
            result.append(strNum[i]);
        return result;
    }
};

版权声明:本文为博主原创文章,未经博主允许不得转载。

解题报告——把数组排成最小的数

原文:http://blog.csdn.net/baidu_28312631/article/details/47354939

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!