输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{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; }