九度 1504:把数组排成最小的数
2014-03-06 21:02
190 查看
题目描述:
输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
思路
1. 最初的想法是比较两个数时, 较短的数末尾补最后一个数, 比如 233, 23 -> 233, 233. 然后判断会变得比较复杂
2. 正好昨晚和室友闲聊, 谈到说到这道题, 才知道末尾补第一个数才是正解. 233, 23 -> 233, 232
3. 剑指 offer 上的解法更是简单粗暴, 直接将两个数拼出来看看就得了. 233, 23 -> 23233, 23323
4. 看完剑指 offer 上的正解, 真想抽自己的脸
代码
输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
思路
1. 最初的想法是比较两个数时, 较短的数末尾补最后一个数, 比如 233, 23 -> 233, 233. 然后判断会变得比较复杂
2. 正好昨晚和室友闲聊, 谈到说到这道题, 才知道末尾补第一个数才是正解. 233, 23 -> 233, 232
3. 剑指 offer 上的解法更是简单粗暴, 直接将两个数拼出来看看就得了. 233, 23 -> 23233, 23323
4. 看完剑指 offer 上的正解, 真想抽自己的脸
代码
#include <iostream> #include <stdio.h> #include <string> #include <cstring> #include <algorithm> using namespace std; int numbers[200]; string str_num[200]; bool cmp(const string &str1, const string &str2) { string _str1 = str1; string _str2 = str2; _str1.append(str2); _str2.append(str1); return _str1 < _str2; } int main() { int n; while(scanf("%d", &n) != EOF) { for(int i = 0; i < n; i ++) scanf("%d", numbers+i); for(int i = 0; i < n; i ++) { char str[20]; sprintf(str, "%d", numbers[i]); str_num[i] = str; } sort(str_num, str_num+n, cmp); for(int i = 0; i < n; i ++) { cout << str_num[i]; } cout << endl; } return 0; }
相关文章推荐
- 找回你删掉并清空回收站的东西
- ZOJ-2724
- java堆和栈
- 无状态服务(stateless service)
- 数据结构之二分法查找、快速排序思想与实现
- 经典数据备份(转载)
- spring之集合注入
- 有寓意的话语
- Axiom3D:数据绑定基本流程
- DBUtils框架(自定义)
- cocos2d-x 街机摇杆 实现
- UVa 10577 Bounding box (直线交点&正多边形中心)
- Delphi 判断时间是否合法 -IsValidDateTime、IsValidDate、IsValidTime、IsValidDateDay
- 基于动态库的C++插件开发模型
- 初学SSH框架所需注意的基本点
- 【原创】第一次写博客
- 推荐一个好的博客下载工具
- 【原创】第一次写博客
- gtk+-3.0- install
- HTTP返回码总结