拼接所有的字符串产生字典序最小的字符串

链接:https://www.nowcoder.com/questionTerminal/d5d1a56491384b2486480730f78f6da2

来源:牛客网

给定一个字符串的数组strs,请找到一种拼接顺序,使得所有的字符串拼接起来组成的字符串是所有可能性中字典序最小的,并返回这个字符串。

输入描述:

输入包含多行,第一行包含一个整数n(1≤n≤105)( 1 \leq n \leq 10^5 )(1≤n≤105),代表字符串数组strs的长度,后面n行,每行一个字符串,代表strs[i](保证所有字符串长度都小于10)。

输出描述:

输出一行,包含一个字符串,代表返回的字典序最小的字符串。

示例1

输入

2

abc

de

输出

abcde

示例2

输入

2

b

ba

输出

bab

备注:

时间复杂度O(nlog2n)O(nlog_2n)O(nlog2​n),额外空间复杂度O(1)O(1)O(1)。

思路:利用排序算法。

#include <iostream>

#include <string>

#include <vector>

#include <algorithm>

using namespace std;

bool cmp(string& a,string& b)

{

    return a + b < b + a;

}

int main()

{

    int n;

    cin >> n;

    vector<string> vs;

    for(int i = 0;i < n;i++)

    {

        string s;

        cin >> s;

        vs.push_back(s);

    }


    sort(vs.begin(),vs.end(),cmp);


    for(int i = 0;i < n;i++)

    {

        cout << vs[i];

    }

    return 0;

}


另一种:手写排序。

#include<iostream>

#include<string>

#include<vector>

usingnamespacestd;

classPrior{

public:

string findSmallest(vector strs,intn)

{

QuickSort(strs,0,n-1);

string res;

for(inti=0;i

res+=strs[i];

return res;

    }

void QuickSort(vector &strs,int low,int high)

{

if(low<high)

{

intres=Partition(strs,low,high);

QuickSort(strs,low,res-1);

QuickSort(strs,res+1,high);

}

}

int Partition(vector &strs,int low,int high)

{

string key=strs[low];

while(low<high)

{

while(low<high&&LT(key,strs[high]))

high--;

strs[low]=strs[high];

while(low<high&&LT(strs[low],key))

low++;

strs[high]=strs[low];

}

strs[low]=key;

return low;

}

bool LT(string s1,string s2)

{

string temp1=s1+s2,temp2=s2+s1;

if(temp1<=temp2)

return true;

else

return false;

}

};

int main()

{

stringa("abc"),b("de"),c("cab");

vector<string> arr;

arr.push_back(b);

arr.push_back(a);

arr.push_back(c);

Prior A;

string res=A.findSmallest(arr,3);

cout<<res;

return 0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值