为什么用户定义的函数不按照给定的顺序对相同长度的元素进行排序?

why doesn't user defined function sort the elements of same length in the order given?

本文关键字:元素 排序 顺序 函数 定义 用户 为什么      更新时间:2023-10-16

我的任务是按字符串长度的递增顺序对单词进行排序,对于相同长度的单词,我必须按给定的顺序排列它们。 例如:"成为或不成为"将变为"成为或不是"。 我首先制作字符串中所有单词的向量"v",然后尝试使用 C++ 的 sort(( 函数中的用户定义函数对向量进行排序。 这是我的代码:

#include <bits/stdc++.h>
using namespace std;
static bool comparelength(string first,string second){//function to compare length
return first.size()<second.size();
}
int main() {
string text="Jlhvvd wfwnphmxoa qcuucx qsvqskq cqwfypww dyphntfz hkbwx xmwohi qvzegb ubogo sbdfmnyeim tuqppyipb llwzeug hrsaebveez aszqnvruhr xqpqd ipwbapd mlghuuwvec xpefyglstj dkvhhgecd kry";
vector<string> v;
string cur="";
text+=" ";

for(int i=0;i<text.size();i++){
if(text[i]==32){//if space is encountered then the word is inserted in the vector
v.push_back(cur);
cur="";
}
else{
cur+=text[i];//if not space then text[i] is added to the current word
}
}
sort(v.begin(),v.end(),comparelength);//sort the vector
for(int i=0;i<v.size();i++)
cout<<v[i]<<" ";

现在它给出以下输出: "Kry xqpqd ubogo hkbwx qvzegb jlhvvd xmwohi qcuucx qsvqskq llwzeug ipwbapd dyphntfz cqwfypww tuqppyipb dkvhhgecd sbdfmnyeim xpefyglstj mlghuuwvec aszqnvruhr hrsaebveez wfwnphmxoa">

但正确的输出应该是: "Kry hkbwx ubogo xqpqd jlhvvd qcuucx xmwohi qvzegb qsvqskq llwzeug ipwbapd cqwfypww dyphntfz tuqppyipb dkvhhgecd wfwnphmxoa sbdfmnyeim hrsaebveez aszqnvruhr mlghuuwvec xpefyglstj">

请参阅位置 1、2 和 3(使用 0 索引(。

它应该给出:HKBWX Ubogo XQPQD。

但它给出了:XQPQD Ubogo HKBWX。

这让我认为它没有按照给定的顺序对相同长度的单词进行排序。您可以找到许多其他发生这种情况的位置(例如:4,5,6 和 7(。

但是对于字符串"leetcode plus try suck geaser 是最好的" 它给出了正确的输出:"是尝试加吸酷最好的Geaser 利特科德">

谁能说清楚为什么它不适用于前一个字符串,而适用于后者。 我试过做

static bool comparelength(string first,string second){
if(first.size()==second.size())
return true;
if(first.size()<second.size())
return true;
else
return false;
}

但这会引发运行时错误。

很抱歉让问题变得混乱,但我真的很想了解这一点。

std::sort不稳定,即等效元素的顺序不一定保留。如果您从std::sort那里获得稳定的排序,那么这只是偶然的。稳定排序更昂贵(O(N·log(N)^2)vsO(N·log(N))(,因此您必须明确要求它。可以用std::stable_sort来完成。

如果要填充std::pair<std::string,size_t>容器,其中second是原始容器中的索引,则可以将std::sort与自定义比较器一起使用。但是,我想使用std::stable_sort更简单。

相关文章: