题目描述
设有n个正整数(n≤20),将它们联接成一排,组成一个最大的多位整数。
例如:n=3时,3个整数13,312,343联接成的最大整数为:34331213
又如:n=4时,4个整数7,13,4,246联接成的最大整数为:7424613
输入格式
第一行,一个正整数n。
第二行,n个正整数。
输出格式
一个正整数,表示最大的整数
样例
输入
3
13 312 343
输出
34331213
思路
显而易见,最高位数大的数排在前边
考虑用string类:string 类的设计允许程序自动处理 string 的大小,因此,与使用数组相比,使用 string 对象更方便,也更安全。
代码
string类陷阱补充
在写代码时,用malloc去给string类型分配内存,结果报错,关于string类几个小陷阱如下:
参考(https://www.cnblogs.com/lanxuezaipiao/p/3704578.html)
malloc&new
来源:https://blog.csdn.net/nie19940803/article/details/76358673
new和malloc的区别是:
1.new、delete是c++的关键字,而malloc、free是库函数
2.使用new不需指定内存块大小,编译器会根据类型信息自行计算,而mallloc则需要显示指出。
3.new分配成功时,返回的是对象指针的类型,类型与对象匹配,无需进行类型转换;而malloc分配成功返回void*,需要再次进行类型转换。
3.new失败时,抛出bac_alloc异常,malloc失败时返回NULL。
4.new会先调用operator new函数,申请足够的内存(通常底层使用malloc实现)。然后调用类型的构造函数,初始化成员变量,最后返回自定义类型指针。delete先调用析构函数,然后调用operator delete函数释放内存(通常底层使用free实现)。
malloc/free是库函数,只能动态的申请和释放内存,无法强制要求其做自定义类型对象构造和析构工作。
5.C++允许重载new/delete操作符,特别的,布局new的就不需要为对象分配内存,而是指定了一个地址作为内存起始区域,new在这段内存上为对象调用构造函数完成初始化工作,并返回此地址。而malloc不允许重载。
6.new操作符从自由存储区(free store)上为对象动态分配内存空间,而malloc函数从堆上动态分配内存。自由存储区是C++基于new操作符的一个抽象概念,凡是通过new操作符进行内存申请,该内存即为自由存储区。而堆是操作系统中的术语,是操作系统所维护的一块特殊内存,用于程序的内存动态分配,C语言使用malloc从堆上分配内存,使用free释放已分配的对应内存。自由存储区不等于堆,如上所述,布局new就可以不位于堆中。
const,c_str
int main() {
string s = "Alexia";
const char *str = s.c_str();
cout << str << endl;
s[1] = 'm';
cout << str << endl;
return 0;
}
//
输出Alexia
Alexim
const char*与char const*是等价的,指的是指向字符常量的指针,即指针可以改变指向但其指向的内容不可以改变,而char* const相反,指的是常量指针,即指向不可以改变但指针指向的内容可以改变。因此这里的const char*指向的内容本类是不可以改变的,那么这里为什么改变了呢?这跟str这个const char*的生命周期及string类的实现有关,string的c_str()返回的指针是由string管理的,因此它的生命期是string对象的生命期,而string类的实现实际上封装着一个char*的指针,而c_str()直接返回该指针的引用,因此string对象的改变会直接影响已经执行过的c_str()返回的指针引用。
代码
跳坑代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n;
cin>>n;
string * shu=new string[n];
for(int i=0;i<n;i++)
{
cin>>shu[i];
}
sort(shu,shu+n);
for(int i=n-1;i>=0;i--)
{
cout<<shu[i];
}
delete []shu;
return 0;
}
这样的思路不能应对以下情况:
65,651
按照字符串大小比较651>65
故会输出65165
但65651更大
正确代码
#include<bits/stdc++.h>
using namespace std;
bool cmp(const string a,const string b)
{
return a+b>b+a;
}
int main()
{
int n;
cin>>n;
string * shu=new string[n];
for(int i=0;i<n;i++)
{
cin>>shu[i];
}
sort(shu,shu+n,cmp);
for(int i=0;i<n;i++)
{
cout<<shu[i];
}
delete []shu;
return 0;
}