栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

牛客网做题笔记 NC 111 最大数

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

牛客网做题笔记 NC 111 最大数

描述
给定一个长度为n的数组nums,数组由一些非负整数组成,现需要将他们进行排列并拼接,每个数不可拆分,使得最后的结果最大,返回值需要是string类型,否则可能会溢出。

数据范围:1 le n le 1001≤n≤100,0 le nums[i] le 100000≤nums[i]≤10000
进阶:时间复杂度O(nlogn)O(nlogn) ,空间复杂度:O(n)O(n)

笔记:
1.vector:动态数组,大小未指定,可动态添加删除
vector ve;定义一个动态的sting类型数组
ve.size():返回动态数组ve的大小,可用在动态数组的循环遍历中,例如 (int i = 0;i

2.ve.push_back(to_string(nums[i]));
to_string:将数值转化成字符串
ve.push_back():向动态数组ve中添加内容

3.sort():c++标准库里的排序函数
Sort(start,end,compare):compare是排序方法,可自定义
疑问:sort()函数具体是如何实现从大到小(或从小到大)的排序的
左右拼接和右左拼接比大小

4.字符串类型相加:
将字符串数组拼接成一个字符串
static bool cmp(string a,string b){
return a+b > b+a;//左右拼接和右左拼接
}
#include
using namespace std;
int main()
{
string a=“3”;
string b=“2”;
cout << a+b;
return 0;
}
输出:32
总结:字符串类型相加不是数字加起来,而是将数字当成字母一样,相加是两个数字放在一起,字母和数字同等看待,都是字符串。
#include
using namespace std;
int main()
{
string a=“e”;
string b=“r”;
cout << a+b;
return 0;
}
输出:er

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/330495.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号