1 条题解
-
0
#include<bits/stdc++.h> using namespace std; struct Person{ int id; int sc; }; const int N=5010; Person p[N]; bool cmp(Person a,Person b) { if(a.sc>b.sc) return 1; //1.成绩从大到小 if(a.sc==b.sc&&a.id<b.id) return 1; //2.成绩相同报名号从小到大 return 0; } int main() { int n,m; cin>>n>>m; for(int i=1;i<=n;i++) cin>>p[i].id>>p[i].sc; sort(p+1,p+n+1,cmp); int k=m*1.5; int t=k; while(t<=n&&p[k].sc==p[t].sc) t++; //走到第一个不相等的地方,或者越界 t--; //回到相等的位置 cout<<p[k].sc<<" "<<t<<endl; for(int i=1;i<=t;i++) { cout<<p[i].id<<" "<<p[i].sc<<endl; } return 0; }
- 1
信息
- ID
- 814
- 时间
- 1000ms
- 内存
- 128MiB
- 难度
- 10
- 标签
- 递交数
- 9
- 已通过
- 3
- 上传者