对数组进行排序并匹配其他数组

sorting array and matching other array

本文关键字:数组 其他 排序      更新时间:2023-10-16

我正在尝试编写一个程序,在其中写入人员的信息,例如:姓名,分钟和秒。我需要按时间对人进行分类。我不明白如何对分钟进行排序并且不会丢失其他数组序列顺序 - 名称和秒。他们只是站在原地。

#include <iostream>          
#include <algorithm>
#include <string>
using namespace std;
struct people{
int min[6], sec[6];
string name[6];
};
int main()
{
int temp;
people z;
for(int i=0; i<6; i++)
{
cin>>z.name[i];
cin>>z.min[i];
cin>>z.sec[i];
}
sort(z.min,z.min+6);
cout<<endl;
for(int i=0; i<6; i++)
{
cout<<z.name[i]<<" "<<z.min[i]<<" "<<z.sec[i]<<endl;
}
return 0;
}
/*Input for example is :
John 6 15  
Liza 9 59 
Michael 19 45 
Kira 2 37 
Thomas 5 41 
Justas 13 24 
/*

正如一些程序员说的那样,你必须有一个结构数组而不是数组结构。但即使在那之后,你也可能会遇到问题,因为你必须在sort函数中填写一个称为函子/比较器的参数。一种更简单的方法是,如果您使用pair<int, pair<string, int> z[6],然后在将所需值输入数组后直接使用sort(z, z+6)。这是因为排序函数可以根据对象的第一个字段(int)按升序对对象数组进行排序。要访问数组中每个三元组的字段,您需要对第一个int字段使用z[i].first,对第二个字符串字段使用z[i].second.first,对最后一个 int 字段使用z[i].second.second。 请注意,比较器或函子是一种帮助定义两个对象之间的排序的方法,这两个对象不是stringint或任何其他标准对象。有关详细信息,请参阅以下内容:https://www.geeksforgeeks.org/functors-in-cpp/和 https://www.geeksforgeeks.org/sorting-a-vector-in-c/。