- 03. 数组中重复的数字
- 04. 二维数组中的查找
- 05.替换空格
- 06.从尾到头打印链表
- 07.重建二叉树
- 09.用两个栈实现队列
- 10-1.斐波那契数列
- 10-2.青蛙跳台阶问题
- 剑指 offer 11.旋转数组的最小数字
- 剑指offer 12.矩阵中的路径
- 剑指offer 13.机器人的运动范围
- 剑指offer 14-1.剪绳子
- 剑指offer 14-2.剪绳子2
- 剑指offer 15.二进制中1的个数
- 剑指offer 16.数值的整数次方
- 剑指offer 17.打印从1到最大的n位数
- 剑指offer 18.删除链表的节点
- 剑指offer 19.正则表达式匹配
- 剑指offer 20.表示数值的字符串
- 剑指offer 21.调整数组顺序使奇数位于偶数前面
- 剑指offer 22.链表中倒数第k个节点
- 剑指offer 24.反转链表
- 剑指offer 25.合并两个排序的链表
- 剑指offer 26.树的子结构
- 剑指offer 27.二叉树的镜像
- 剑指offer 28.对称的二叉树
- 剑指offer 29.顺时针矩阵
- 剑指offer 30.包含min函数的栈
- 剑指offer 31.栈的压入、弹出序列
- 剑指offer 32-1.从上到下打印二叉树
- 剑指offer 32-2.从上到下打印二叉树
- 剑指offer 32-3.从上到下打印二叉树
- 剑指offer 33.二叉搜索树的后序遍历序列
- 剑指offer 34.二叉树中和为某一值的路径
- 剑指offer 35.复杂链表的复制
- 剑指offer 36.二叉搜索树与双向链表
- 剑指offer 37.序列化二叉树
- 剑指offer 38.字符串的排列
- 剑指 offer 39. 数组中出现次数超过一半的数字
- 剑指offer 40. 最小的k个数
- 剑指offer 41.数据流中的中位数
- 剑指offer 42. 连续子数组的最大和
- 剑指offer 43. 1~n整数中1出现的次数
- 剑指offer 44. 数字序列中某一位的数字
- 剑指offer 45. 把数组排成最小的数
- 剑指offer 46.把数字翻译成字符串
- 剑指offer 47.礼物的最大值
- 剑指offer 48.最长不含重复字符的字符子串
- 剑指offer 49.丑数
- 剑指offer 50.第一个只出现一次的字符
- 剑指offer 51. 数组中的逆序对
- 剑指offer 52.两个链表的第一个公共节点
- 剑指offer 53-1. 在排序数组中查找数字
- 剑指offer 53-2. 0~n-1中缺失的数字
- 剑指offer 54. 二叉搜索树的第k大节点
- 剑指offer 55-1. 二叉树的深度
- 剑指offer 55-2. 平衡二叉树
- 剑指offer 56-1. 数组中数字出现的次数
- 剑指offer 56-2. 数字中出现的次数
- 剑指offer 57-1. 和为s的两个数字
- 剑指offer 57-2. 和为s的连续正数序列
- 剑指offer 58-1. 翻转单词顺序
- 剑指offer 58-2.左旋转字符串
- 剑指offer 59-1. 滑动窗口的最大值
- 剑指offer 59-2. 队列的最大值
- 剑指offer 60. n个骰子的点数
- 剑指offer 61. 扑克牌中的顺子
- 剑指offer 62. 圆圈中最后剩下的数字
- 剑指offer 63. 股票的最大利润
- 剑指offer 64. 求1+2+…+n
- 剑指offer 65. 不用加减乘除做加法
- 剑指offer 66. 构建乘积数组
- 剑指offer 67. 把字符串转成整数
- 剑指offer 68-1. 二叉搜索树的最近公共祖先
- 剑指offer 68-2. 二叉树的最近公共祖先
剑指offer 68-2. 二叉树的最近公共祖先
题目描述
输入一个非负整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。
示例 1:
输入: [10,2]
输出: "102"
示例 2:
输入: [3,30,34,5,9]
输出: "3033459"
提示:
- 0 < nums.length <= 100
说明:
- 输出结果可能非常大,所以你需要返回一个字符串而不是整数
- 拼接起来的数字可能会有前导 0,最后结果不需要去掉前导 0
题解
(排序,自定义比较器) O(nlogn)
这道题目的巧妙之处是可以通过自定义排序方式将数组排序得到结果。
自定义排序方式:数字类型的 a < b 当前仅当字符串类型的 a + b < b + a,即 ab 排列组成的数字小于 ba 排列组成的数字 ab < ba,排序之后依次遍历数组的结果就是最小的数。
时间复杂度
时间复杂度为排序所需的时间 O(nlogn)
空间复杂度
O(1)
C++ 代码
class Solution {
public:
static bool cmp(int& a, int& b) {
string as = to_string(a), bs = to_string(b);
return as + bs < bs + as;
}
string minNumber(vector<int>& nums) {
sort(nums.begin(), nums.end(), cmp);
string res;
for (auto x : nums) res += to_string(x);
return res;
}
};
Java 代码
class Solution {
public String minNumber(int[] nums) {
String[] strNums = new String[nums.length];
for (int i = 0; i < nums.length; i ++ ) {
strNums[i] = String.valueOf(nums[i]);
}
Arrays.sort(strNums, (a, b) -> (a + b).compareTo(b + a));
StringBuilder res = new StringBuilder();
for (String str : strNums) {
res.append(str);
}
return res.toString();
}
}
Python 代码
class Solution:
def minNumber(self, nums: List[int]) -> str:
key = cmp_to_key(lambda x, y: int(x + y) - int(y + x))
nums = sorted(map(str, nums), key=key)
return "".join(nums)
本文由读者提供,Github地址:https://github.com/tonngw
点击面试手册,获取本站面试手册PDF完整版