当前位置:网站首页>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;
}边栏推荐
- How to find out the currently running version of Solr- How do I find out version of currently running Solr?
- Shell implements basic file operations (SED edit, awk match)
- 关于QByteArray存储十六进制 与十六进制互转
- Vulkan-实践第一弹
- 使用jenkins之二Job
- Baidu AI Cloud takes the lead in building a comprehensive and standardized platform for smart cloud
- Leetcode-241: designing priorities for operational expressions
- 【AutoSAR 六 描述文件】
- Leetcode-224: basic calculator
- 【案例分享】让新时代教育发展与“数”俱进
猜你喜欢

1.12 - Instructions

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

Arduino开发之按键检测与正弦信号输出

Use Jenkins II job

【AutoSAR 六 描述文件】

Infrared thermography temperature detection system based on arm rk3568

The arm core board / development board of Feiling equipped with Ti am62x made its debut in embedded world 2022

Kubernetes resource object introduction and common commands (V) - (NFS & PV & PVC)

leetcode-2280:表示一个折线图的最少线段数
![[AUTOSAR + IO Architecture]](/img/cf/9ea42b50bed298c0546764b63bd957.png)
[AUTOSAR + IO Architecture]
随机推荐
Rust string slicing, structs, and enumeration classes
Hdu3507 (slope DP entry)
lex && yacc && bison && flex 配置的问题
[AUTOSAR II appl overview]
[AUTOSAR I overview]
Rust字符串切片、结构体和枚举类
[AUTOSAR + IO Architecture]
Leetcode-224: basic calculator
【日常训练】871. 最低加油次数
瑞萨RZ/G2L 处理器简介|框架图|功耗|原理图及硬件设计指南
1.11 - bus
Solve the cache problem of reactnative using WebView
leetcode-2115:从给定原材料中找到所有可以做出的菜
数组与集合性能比较
There is an unknown problem in inserting data into the database
Leetcode-871: minimum refueling times
About qbytearray storage hexadecimal and hexadecimal conversion
An excellent orm in dotnet circle -- FreeSQL
[overview of AUTOSAR three RTE]
数学建模之线性规划(含MATLAB代码)