当前位置:网站首页>1038 Recover the Smallest Number
1038 Recover the Smallest Number
2022-07-03 00:57:00 【Brosto_ Cloud】
Given a collection of number segments, you are supposed to recover the smallest number from them. For example, given { 32, 321, 3214, 0229, 87 }, we can recover many numbers such like 32-321-3214-0229-87 or 0229-32-87-321-3214 with respect to different orders of combinations of these segments, and the smallest number is 0229-321-3214-32-87.
Input Specification:
Each input file contains one test case. Each case gives a positive integer N (≤104) followed by N number segments. Each segment contains a non-negative integer of no more than 8 digits. All the numbers in a line are separated by a space.
Output Specification:
For each test case, print the smallest number in one line. Notice that the first digit must not be zero.
Sample Input:
5 32 321 3214 0229 87
Sample Output:
22932132143287
Custom sort function :
When two strings are not prefixed by one and the other , Sort directly in ascending order ;
When one is the prefix of another : Take the first character after the prefix of a long string ( That is, when the short string length is length when , Take the long string s[length]) Compare it with the first character of the short string , Put the smaller one in front ;
This ensures that the order between each two strings must be the smaller of the two permutations .
After sorting, the answer string is formed in a new order , Take care to remove leading zeros , Note that the answer is 0 The situation of .
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
string a[10010];
bool cmp(string s1, string s2) {
int length = min(s1.size(), s2.size());
for (int i = 0; i < length; i++) {
if (s1[i] != s2[i]) {
return s1 < s2;
}
}
if (s1.size() < s2.size()) {
if (s2[length] > s1[0]) {
return true;
} else {
return false;
}
} else {
if (s1[length] > s2[0]) {
return false;
} else {
return true;
}
}
}
int main() {
int n;
cin >> n;
for (int i = 0; i < n; i++) {
cin >> a[i];
}
sort(a, a + n, cmp);
bool flag = 0;
string ans = "";
for (int i = 0; i < n; i++) {
ans += a[i];
}
for (int i = 0; i < ans.size(); i++) {
if (ans[i] != '0') {
flag = 1;
}
if (flag) {
cout << ans[i];
}
}
if (flag == 0) {
cout << 0;
}
return 0;
}
边栏推荐
- Leetcode-241: designing priorities for operational expressions
- 百度智能云牵头打造智能云综合标准化平台
- Extension of flutter
- Leetcode-2115: find all the dishes that can be made from the given raw materials
- [jetcache] jetcache configuration description and annotation attribute description
- Rust字符串切片、结构体和枚举类
- 【C语言】分支和循环语句(上)
- Shell 实现文件基本操作(sed-编辑、awk-匹配)
- 递归处理组织的几种情况
- Web2.0 giants have deployed VC, and tiger Dao VC may become a shortcut to Web3
猜你喜欢
[shutter] image component (the placeholder | transparent_image transparent image plug-in is loaded into the memory)
[overview of AUTOSAR three RTE]
Rust string slicing, structs, and enumeration classes
【AutoSAR 十一 通信相关机制】
【AutoSAR 十 IO架构】
The difference between tail -f, tail -f and tail
【AutoSAR 四 BSW概述】
Unity learns from spaceshooter to record the difference between fixedupdate and update in unity for the second time
[AUTOSAR 11 communication related mechanism]
Rust字符串切片、结构体和枚举类
随机推荐
Vulkan-实践第一弹
世平信息首席科学家吕喆:构建以数据和人员为中心的安全能力
1.12 - 指令
深度剖析数据在内存中的存储
Hdu3507 (slope DP entry)
1.12 - Instructions
Arduino开发之按键检测与正弦信号输出
lex && yacc && bison && flex 配置的問題
[introduction to AUTOSAR seven tool chain]
【C语言】分支和循环语句(上)
Shell implements basic file operations (cutting, sorting, and de duplication)
mysql 多表联合删除
瑞萨电子RZ/G2L开发板上手评测
【案例分享】让新时代教育发展与“数”俱进
详解RDD基本概念、RDD五大属性
【AutoSAR 五 方法论】
[AUTOSAR eight OS]
leetcode-871:最低加油次数
leetcode-934:最短的桥
Sentry developer contribution Guide - configure pycharm