原题地址:

https://oj.leetcode.com/problems/largest-number/

题目内容:

Given a list of non negative integers, arrange them such that they form the largest number.

For example, given [3, 30, 34, 5, 9], the largest formed number is 9534330.

Note: The result may be very large, so you need to return a string instead of an integer.

方法:

非常简单。

0. 定义两个整数的大小方式:有整数A和B,若AB > BA,则A > B

1. 调用sort,传入重新定义的比较函数,按递减排序。

2. 从0开始,将每个整数转为字符串,并push到结果字符串的末尾。结果字符串当然要初始化为0.

这里稍微提一下两个整数的大小比较方式。A = 9,B = 12这种情况就不说了,假设A的长度小于B,而且若A和B的前半部分完全一致,A和B的大小怎么处理?例如A = 12, B = 128的情况,还有A = 9,B = 912的情况。

不妨设B和A不相等的部分为C,则第一种情况C = 8,第二种情况C = 12。那么实际上B = AC,AB = AAC, BA = ACA。容易看出,AB和BA的头肯定是A,关键是AC大还是CA大。若AC大,则A大于B,若CA大,则B大于A。

当然你也可以简单粗暴直接把AB和BA连接起来,从字符串的角度看看谁大。这个我没有试过,不知道会不会TLE。可惜由于溢出问题,所以不能用整数表示,只能用字符串。

经验教训:

开始老是出RE,结果问题居然是sort函数:传入的compare方法不能同时对A < B和B < A返回真,也就是说,不能写类似 return A <= B的语句,否则sort会读一些乱七八糟的内存区域,然后就挂了

全部代码:

class Solution {
public:
// define x < y. when x < y return true.
static bool compare(int x,int y) {
string a = strval(x);
string b = strval(y);
int length = a.size() > b.size() ? b.size() : a.size();
for (int i = 0; i < length; i ++) {
if (a[i] != b[i]) {
return a[i] - b[i] > 0;
}
}
return a.size() < b.size() ?
(b.compare(b.substr(a.size()) + b.substr(0,a.size())) > 0 ? true : false)
:
(a.compare(a.substr(b.size()) + a.substr(0,b.size())) < 0 ? true : false);
}
string largestNumber(vector<int> &num) {
sort(num.begin(),num.end(),compare);
if (num[0] == 0) {
return "0";
}
string result = "";
for (int i = 0; i < num.size(); i ++) {
result += strval(num[i]);
}
return result;
} static string strval(int num) {
char tmp[20];
char index = 0;
while (num >= 10) {
tmp[index ++] = (char)(num % 10 + '0');
num /= 10;
}
tmp[index] = (char)(num + '0');
string res = "";
for (int i = index; i >= 0; i --) {
res = res + tmp[i];
}
return res;
}
};

  

【原创】leetCodeOj --- Largest Number 解题报告的更多相关文章

  1. 【LeetCode】Largest Number 解题报告

    [LeetCode]Largest Number 解题报告 标签(空格分隔): LeetCode 题目地址:https://leetcode.com/problems/largest-number/# ...

  2. LeetCode: Largest Number 解题报告 以及Comparator, CompareTo 应用

    Largest Number Given a list of non negative integers, arrange them such that they form the largest n ...

  3. 【LeetCode #179】Largest Number 解题报告

    原题链接:Largest Number 题目描述: Given a list of non negative integers, arrange them such that they form th ...

  4. 【九度OJ】题目1040:Prime Number 解题报告

    [九度OJ]题目1040:Prime Number 解题报告 标签(空格分隔): 九度OJ 原题地址:http://ac.jobdu.com/problem.php?pid=1040 题目描述: Ou ...

  5. 【LeetCode】306. Additive Number 解题报告(Python)

    [LeetCode]306. Additive Number 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http: ...

  6. [LeetCode] 179. Largest Number 解题思路

    Given a list of non negative integers, arrange them such that they form the largest number. For exam ...

  7. USACO Section1.2 Name That Number 解题报告

    namenum解题报告 —— icedream61 博客园(转载请注明出处)-------------------------------------------------------------- ...

  8. 【LeetCode】1133. Largest Unique Number 解题报告(C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 桶排序 日期 题目地址:https://leetcod ...

  9. 【原创】leetCodeOj --- Min Stack 解题报告

    题目地址: https://oj.leetcode.com/problems/min-stack/ 题目内容: Design a stack that supports push, pop, top, ...

随机推荐

  1. 中国大概可用NTPserver地址

    133.100.11.8 prefer210.72.145.44203.117.180.36131.107.1.10time.asia.apple.com64.236.96.53130.149.17. ...

  2. [Android学习笔记]EditText的使用

    EditText就是我们最常用的文本输入框 常用属性见官方文档 主要是以下几个问题: 1.取消默认获取焦点 Activity启动时候会把焦点默认停留在第一个EditText控件上 一般的解决方法是在此 ...

  3. ZXing拍摄代码扫描之后以区分一维码、二维码、其他代码

    我怎么有二维码没有联系,最近遇到一个问题,,如何推断条码扫描到一维代码或者二维代码,辛苦了一个下午下班后自己,加上网上跟踪信息. 总结出两种方式能够解决该问题(推荐採用另外一种方式): 1.改动源代码 ...

  4. 在RHEL上安装Thrift(支持C++)的若干问题 » 编码无悔 / Intent & Focused

    在RHEL上安装Thrift(支持C++)的若干问题 » 编码无悔 / Intent & Focused [原创]在RHEL上安装Thrift(支持C++)的若干问题    2010年12月1 ...

  5. POJ 2365 Rope(水题)

    [题意简述]:给出我们钉子个数与半径,让我们求出缠绕在钉子上的绳子有多长. [分析]:从题目中我们能够看出,绳子长度的和等于每两个钉子的距离的和加上接触在钉子上的绳子的长度,不难发现这部分长度事实上就 ...

  6. ORA-00210 ORA-15001 ORA-15055 ORA-01031: insufficient privileges

    ORA-00210: cannot open the specified control file ORA-00202: control file: &apos;+DATA/posdb/con ...

  7. Android的内存优化

    腾讯公司在五月三十一日开展[腾讯Bugly移动开发人员沙龙]大会.大会上面叶方正老师解说了 关于Android的内存优化的问题,只是我感觉叶老师许多其它的站在了測试的角度上去解释了这一方面,叶老师给我 ...

  8. C#多线程问题整合

    一.跨进程访问组件 错误:线程间操作无效: 从不是创建控件“XXX”的线程访问它 解决方法: 1:把CheckForIllegalCrossThreadCalls设置为false 这个方法只是不去捕获 ...

  9. sleep和wait的区别

    sleep指线程被调用时,占着CPU不工作,形象地说明为“占着CPU睡觉”,此时,系统的CPU部分资源被占用,其他线程无法进入,会增加时间限制.wait指线程处于进入等待状态,形象地说明为“等待使用C ...

  10. SVN配置文件详解

    本章将详细介绍前一章所涉及的两个配置文件, svnserve.conf 和 authz.conf,通过对配置逐行的描述,来阐明其中的一些细节含义.除此之外的其他配置.安装等内容,不是本文重点,读者若有 ...