拼数(string类)

题目描述

设有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;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值