原题地址:

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. 14.3.5.3 How to Minimize and Handle Deadlocks 如何减少和处理死锁

    14.3.5.3 How to Minimize and Handle Deadlocks 如何减少和处理死锁 这个章节建立关于死锁的概念信息,它解释如何组织数据库操作来减少死锁和随后的错误处理: D ...

  2. 无法引入import com.sun.management.OperatingSystemMXBean

    现象:在JDK的安装包的jre\lib\rt.jar包里确实有这个类com.sun.management.OperatingSystemMXBean,但是就是不能import  com.sun.man ...

  3. GitHub上最火的40个iOS开源项目

    1. AFNetworking 在众多iOS开源项目中,AFNetworking可以称得上是最受开发者欢迎的库项目.AFNetworking是一个轻量级的iOS. Mac OS X网络通信类库,现在是 ...

  4. Oracle 调用存储过程执行CRUD的小DEMO

    -----------------------------修改(表名,主键ID,要修改的列) create or replace procedure pro_code_edit(p_tbname in ...

  5. SVN最有效的方法打基线

    笔者:张克强    在微博上:张克强-敏捷307 2014/7/6 方法一来自于我的一条微博: 组织级scm建一个名为controlled的文件夹,当项目某文档通过评审后,组织级scm从项目文件夹下找 ...

  6. AntiXSS - 支持Html同时防止XSS攻击

    AntiXSS - 支持Html同时防止XSS攻击 跨站脚本攻击(XSS)已经不是什么新鲜的话题了,甚至很多大公司也为此吃尽苦头.最简单直接的防范方法,就是不允许任何html标签输入,对用户输入进行编 ...

  7. C# 文件操作(全部) 追加、拷贝、删除、移动文件、创建目录 修改文件名、文件夹名

    原文:C# 文件操作(全部) 追加.拷贝.删除.移动文件.创建目录 修改文件名.文件夹名 本文也收集了目前最为常用的C#经典操作文件的方法,具体内容如下:C#追加.拷贝.删除.移动文件.创建目录.递归 ...

  8. C++实现链栈的基本操作

    之前对顺序栈写了基本操作,认为有必要也动手练练栈的链表实现. 对于链栈,一般不会出现栈满的情况. 链栈头文件定义例如以下: #ifndef CSTOCK_H_ #define CSTOCK_H_ ty ...

  9. java 参数传递

    由一个问题来引入参数传递的问题 public static void main(String[] args) { int x=1; int[] y =new int[10]; m(x,y); Syst ...

  10. windows server 2012显示桌面图标

    windows server 2012安装后是没有桌面图标的,可以通过下面方式显示出来: 打开powershell rundll32.exe shell32.dll,Control_RunDLL de ...