您的位置:首页 > 其它

Leetcode160: Largest Number

2015-11-17 21:47 501 查看
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.

class Solution {
public:
static bool compare(string& s1, string& s2)
{
return (s1+s2)>(s2+s1);
}
string largestNumber(vector<int>& nums) {
vector<string> num(nums.size());
for(int i = 0; i < nums.size(); i++)
{
num[i] = to_string(nums[i]);
}
sort(num.begin(), num.end(), compare);
string res;
bool flag = false;
for(int i = 0; i < num.size(); i++)
{
if(num[i] != "0"){
res += num[i];
flag = true;
}
else if(flag)
{
res += num[i];
}
}
if(!flag) res.push_back('0');
return res;
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: