gpt4 book ai didi

c++ - 按成员降序对多个对象进行排序?

转载 作者:行者123 更新时间:2023-11-30 01:58:48 25 4
gpt4 key购买 nike

我看过以下问题:根据对象的属性对对象的 vector 进行排序

这似乎与我的情况非常相关。我有少量 Player 对象 (6-10),它们都有名称等信息,以及一些相关统计数据。我想按一个特定的统计数据以降序对它们进行排序。

还是很迷茫

请帮忙!

编辑:下面的完整更新代码

#include <iostream>
#include <string>
#include <algorithm>
#include <vector>

using namespace std;

class Player {
public:
Player(string name, int Dex, int Mod, int Lvl, int& diceRoll);

int calcInitiative(int& diceRoll);

int diceRoll;

friend ostream& operator<<(ostream& out, const Player& player) {
return out << player.mName << " " << player.mInitiative;
}

bool operator<(const Player& rhs) const {

if(mInitiative < rhs.mInitiative) return true;

if(mInitiative > rhs.mInitiative) return false;

if(mInitiative == rhs.mInitiative) return false;

}

int mDex, mMod, mLvl, mInitiative;
string mName;
};

Player::Player(string name, int Dex, int Mod, int Lvl, int& diceRoll)
: mName(name), mDex(Dex), mMod(Mod), mLvl(Lvl)
{}


int Player::calcInitiative(int& diceRoll) {

return (mLvl/2) + mDex + mMod + diceRoll;
}

int main() {

int rollD, rollS; // etc.

vector<Player> playerVec;

cout << "Derek rolled: ";
cin >> rollD;
cout << '\n' << "Scott rolled: ";
cin >> rollS;

// etc.


Player Derek("Derek", 2, 0, 6, rollD);
Player B("B", 2, 0, 9, rollB);

// etc...

Derek.mInitiative = Derek.calcInitiative(rollD);
Scott.mInitiative = Scott.calcInitiative(rollS);

//etc.

playerVec.push_back(Derek);
playerVec.push_back(Scott);

// etc.

cout << "The initative order is: " << '\n';

sort (playerVec.begin(), playerVec.end());

for(vector<Player>::iterator it = playerVec.begin(); it != playerVec.end(); ++it) {
cout << *it << endl;
}

system("pause");

return 0;
}

最佳答案

您几乎已经编写了所有代码。

在您的 Player 类中,添加以下函数:

bool operator<(const Player& rhs) const;

如果this,让它返回真小于右侧。类似于您的上一个代码块。

现在运行:

sort(myVec.begin(), myVec.end());

这将执行就地排序。

编辑:这是一个完全可编译的示例,展示了它们如何协同工作:

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

class Player
{
public:
Player(int stat1, int stat2) : m_stat1(stat1), m_stat2(stat2) {}

bool operator<(const Player& rhs) const {
if(m_stat1 < rhs.m_stat1) return true;
if(m_stat1 > rhs.m_stat1) return false;
return m_stat2 < rhs.m_stat2;
}

friend ostream& operator<<(ostream& out, const Player& player) {
return out << player.m_stat1 << ", " << player.m_stat2;
}

private:
int m_stat1, m_stat2;
};

int main()
{
vector<Player> aPlayers;
aPlayers.push_back(Player( 1, 2 ));
aPlayers.push_back(Player( 1, 1 ));
aPlayers.push_back(Player( 5, 0 ));

std::sort(aPlayers.begin(), aPlayers.end());

for(vector<Player>::iterator it = aPlayers.begin();
it != aPlayers.end(); ++it)
{
cout << *it << endl;
}
}

输出:

1, 1
1, 2
5, 0

我把 operator<< 放在那里,因为你在评论中提到了它,但它实际上与排序无关。没有它,std::sort() 也能正常工作。

编辑 2:对于您的新代码,您提到编译器给您一个错误。该错误很可能是因为无法确定代码是否会返回值。如果添加 return falseoperator< 结束,它会停止给你一个错误。这也会成为你的第三行 operator<多余的。

就结果倒序而言,sort默认按升序排序。有几个非常简单的方法可以解决这个问题。最明显的是重写operator<生成您喜欢的顺序。一个更通用的选项是将反向迭代器提供给 std::sort 而不是默认迭代器:

std::sort(aPlayers.rbegin(), aPlayers.rend());

rbegin()rend()就像begin()end() , 除了它们是相反的。

关于c++ - 按成员降序对多个对象进行排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16857191/

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