gpt4 book ai didi

c++ - 这是使用 std::sort() 的最佳方式吗?

转载 作者:行者123 更新时间:2023-12-01 14:09:18 25 4
gpt4 key购买 nike

我有一个包含 5 个单词的 vector 被多次使用,我想要的是实现这样的单词顺序:“a, zawodowe, wyzsze, podstawowe, bez wyksztalcenia”
所以我写了这段代码,我想知道它是否是使用排序的最佳方式,或者可以跳过 if 条件之一

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;


int main()
{
std::vector<std::string> v = {"wyzsze", "podstawowe", "zawodowe","podstawowe",
"zawodowe", "bez wyksztalcenia", "zawodowe", "zawodowe", "wyzsze",
"zawodowe", "zawodowe", "wyzsze", "podstawowe", "bez wyksztalcenia",
"wyzsze", "podstawowe", "zawodowe","podstawowe",
"zawodowe", "bez wyksztalcenia", "zawodowe", "zawodowe", "wyzsze",
"zawodowe", "zawodowe", "wyzsze", "podstawowe", "bez wyksztalcenia",
"wyzsze", "podstawowe", "zawodowe","podstawowe",
"zawodowe", "bez wyksztalcenia", "zawodowe", "zawodowe", "wyzsze",
"zawodowe", "zawodowe", "wyzsze", "podstawowe", "bez wyksztalcenia",
"wyzsze", "podstawowe", "zawodowe","podstawowe",
"zawodowe", "bez wyksztalcenia", "zawodowe", "zawodowe", "wyzsze",
"zawodowe", "zawodowe", "wyzsze", "podstawowe", "bez wyksztalcenia", "a" };

//return a>b daje: zawodowe, wyzsze, podstawowe, bez wyksztalcenia, a
std::sort(v.begin(), v.end(), [](std::string a, std::string b){
if(a == "zawodowe" && b == "a") return false;
if(a == "a" && b == "zawodowe") return true;
if(a == "wyzsze" && b == "a") return false;
if(a == "podstawowe" && b == "a") return false;
if(a == "bez wyksztalcenia" && b == "a") return false;
return a>b;

});

for (std::string i: v) {
std::cout << i << std::endl;
}
}

最佳答案

这应该足够了:

[](std::string a, std::string b){
if(b == "a") return false;
if(a == "a") return true;
return a>b;
}

关于c++ - 这是使用 std::sort() 的最佳方式吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60606072/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com