#include <iostream>
#include <vector>
#include <set>
//#include <conio.h>
using UI = unsigned int;
struct Stud {
std::vector<UI> res;
UI id;
Stud(UI a = 0, std::vector<UI> re = std::vector<UI>()) : id(a), res(re)
{
}
bool operator>(const Stud& com) const
{
if (res != com.res)
return res > com.res;
else
return id > com.id;
}
bool operator<(const Stud& com) const
{
if (res != com.res)
return res < com.res;
else
return id < com.id;
}
bool operator==(const Stud& com) const
{
return res == com.res;
}
};
int main()
{
UI n, m;
std::cin >> n >> m;
//n - ilość pomiarów
//m - ilość dzieci
std::vector<UI> alina;
alina.resize(n); //stworzenie tablicy z pomiarami aliny
for (UI i = 0; i < n; i++)
{
std::cin >> alina[i];
}
//a teraz klasa ucznia aliny i reszta studentów
std::set<Stud> students;
//dodanie aliny
students.emplace(1, alina);
for (UI i = 2; i <= m; i++)
{
UI it;
std::cin >> it;
std::cin >> alina[it-1];
students.emplace(i, alina);
}
for (Stud v : students)
{
std::cout << v.id << ' ';
}
//_getch();
return 0;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 | #include <iostream> #include <vector> #include <set> //#include <conio.h> using UI = unsigned int; struct Stud { std::vector<UI> res; UI id; Stud(UI a = 0, std::vector<UI> re = std::vector<UI>()) : id(a), res(re) { } bool operator>(const Stud& com) const { if (res != com.res) return res > com.res; else return id > com.id; } bool operator<(const Stud& com) const { if (res != com.res) return res < com.res; else return id < com.id; } bool operator==(const Stud& com) const { return res == com.res; } }; int main() { UI n, m; std::cin >> n >> m; //n - ilość pomiarów //m - ilość dzieci std::vector<UI> alina; alina.resize(n); //stworzenie tablicy z pomiarami aliny for (UI i = 0; i < n; i++) { std::cin >> alina[i]; } //a teraz klasa ucznia aliny i reszta studentów std::set<Stud> students; //dodanie aliny students.emplace(1, alina); for (UI i = 2; i <= m; i++) { UI it; std::cin >> it; std::cin >> alina[it-1]; students.emplace(i, alina); } for (Stud v : students) { std::cout << v.id << ' '; } //_getch(); return 0; } |
English