0

我正在尝试从球员曲棍球统计数据的二进制文件中对列表进行排序。我的目标是使用选择排序算法根据游戏中的点数按降序对列表进行排序,其中点数 = 进球 + 助攻。

我正在使用一个结构数组,其中每个数组都是球员统计数据的结构。

这是结构。

struct Player
{
 char name[20];
 int goals;
int assists;
int rating;
};

到目前为止,这就是我在排序数组函数中所拥有的。

 void sortArrays( Player players[], int numPlayers)
int top=0;
int ssf;
int last=numPlayers;
int ptr;
int i = 0;
Player temp;

while (top < last)    
{
    ptr=top;
    ssf=top;

    pnts = players[i].goals + players[i].assists;
    i++;
}

在这之后我被卡住了。

以下是该函数在广义上应该执行的步骤。

  1. 使用公式 points = player[i].goals + player[i].assists 计算点数

  2. 根据点数按降序对结构数组进行排序。

  3. 交换不同的数组,直到列表按从最大到最少的点数降序排列。

4

1 回答 1

0

你必须使用选择排序吗?std::sort如果您定义自定义比较函数,则可以改用:

bool compare_players(Player const& a, Player const& b) {
  return (b.goals + b.assists) < (a.goals + a.assists);
}

然后把你的玩家扔进跟注vectorplayers

std::sort(players.begin(), players.end(), &compare_players);

这比实现选择排序(O(n^2) )代码更少,而且效率更高(O(n log n))。

于 2013-04-10T22:44:59.200 回答