解题报告——把数组排成最小的数
2015-08-08 08:48
666 查看
题目:输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这3个数字能排成的最小数字321323。
思路:首先,看到题目就要想到先把整数转换为字符串,因为结果肯定是一个大数。然后分析这道题目的本质,其实就是要对转换后的字符串进行排序,然后顺序输出即可,至于排序的方式需要自己定义。举个例子,题目中的字符串“3”和“32”,我们对这两个字符串的“大小”进行排序时,如果“3”在前面,则输出结果为“332”,很显然最后结果比“323”要大。因此我们定义排序方式时,不是比较a和b,而且比较ab和ba,如果ab小,则a排在前面,否则b排在前面。因此可以写出代码。
下面是我自己的代码,一次AC。
思路:首先,看到题目就要想到先把整数转换为字符串,因为结果肯定是一个大数。然后分析这道题目的本质,其实就是要对转换后的字符串进行排序,然后顺序输出即可,至于排序的方式需要自己定义。举个例子,题目中的字符串“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; } };
相关文章推荐
- Android eclipse导入项目后出现Unable to resolve target 'android-17'解决方法
- Font '??' is not available to the JVM. See the Javadoc for more details.
- 工作总结书写的意义及要求
- weblogic.xml 部署描述符元素
- poj 1458 Common Subsequence
- eclipse中常用的快捷键
- 生日
- Android Studio开发环境搭建
- 工作总结的写作方法与要领
- Python字符串操作集锦之字符串编码解码函数
- 学生成绩判断函数接口
- Task.FromResult应用场景举例
- 全面工作总结的写作技巧和写作要点
- iOS开发 - UIViewController控制器管理
- 一个可以一直滚动的ImageView
- HDU2.1.5 找新朋友
- 【HDU4283】【You Are the One】
- 从nand拷贝到sdram
- leetcode 221 Maximal Square
- (五)面向对象的设计原则之一