当前位置:网站首页>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:
22932132143287Custom 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;
}边栏推荐
- AttributeError: ‘tuple‘ object has no attribute ‘layer‘问题解决
- Problèmes de configuration lex & yacc & Bison & Flex
- 递归处理组织的几种情况
- Nc17059 queue Q
- The "2022 China Digital Office Market Research Report" can be downloaded to explain the 176.8 billion yuan market in detail
- Key detection and sinusoidal signal output developed by Arduino
- 关于QByteArray存储十六进制 与十六进制互转
- Tensorflow 2.x(keras)源码详解之第十五章:迁移学习与微调
- 【JetCache】JetCache的配置说明和注解属性说明
- 全志A40i/T3如何通过SPI转CAN
猜你喜欢

Rust字符串切片、结构体和枚举类

Illustrated network: what is virtual router redundancy protocol VRRP?

Callback event after the antv X6 node is dragged onto the canvas (stepping on a big hole record)

Sentry developer contribution Guide - configure pycharm

【AutoSAR 四 BSW概述】

Linux软件:如何安装Redis服务

Rust string slicing, structs, and enumeration classes

Vulkan-性能及精细化

【案例分享】让新时代教育发展与“数”俱进
![[overview of AUTOSAR three RTE]](/img/6a/0df33beb42f165af77a17b5d8b01e2.png)
[overview of AUTOSAR three RTE]
随机推荐
【AutoSAR 二 AppL概述】
Nc17059 queue Q
leetcode-2280:表示一个折线图的最少线段数
Sentry developer contribution Guide - configure pycharm
lex && yacc && bison && flex 配置的问题
Baidu AI Cloud takes the lead in building a comprehensive and standardized platform for smart cloud
1038 Recover the Smallest Number
测试右移:线上质量监控 ELK 实战
2022上半年值得被看见的10条文案,每一句都能带给你力量!
Problèmes de configuration lex & yacc & Bison & Flex
Kubernetes resource object introduction and common commands (V) - (NFS & PV & PVC)
[AUTOSAR I overview]
KingbaseES ALTER TABLE 中 USING 子句的用法
How to find out the currently running version of Solr- How do I find out version of currently running Solr?
Detailed explanation of pod life cycle
全志A40i/T3如何通过SPI转CAN
百度智能云牵头打造智能云综合标准化平台
Shell 实现文件基本操作(sed-编辑、awk-匹配)
Test shift right: Elk practice of online quality monitoring
【案例分享】让新时代教育发展与“数”俱进