题解:
需要注意的是,快排完之后并不是按照编号从小到大的顺序输出
#include<iostream>
using namespace std;
int r=0;
void swap(int &a,int &b){
int t=a;
a=b;
b=t;
}
void sort(int s[],int l,int r,int k[])
{
int mid=s[(l+r)/2];
int i=l,j=r;
do{
while(s[i]>mid) i++;
while(s[j]<mid) j--;
if(i<=j)
{
swap(s[i],s[j]);
swap(k[i],k[j]);
i++;
j--;
}
}while(i<=j);
if(l<j) sort(s,l,j,k);
if(i<r) sort(s,i,r,k);
}
void sort2(int s[],int k[],int i)
{
if(k[i]>k[i+1]){
swap(k[i],k[i+1]);
}
r=i+1;
if(s[r]==s[r+1]){
sort2(s,k,r);
}else{
return;
}
if(k[i]>k[i+1]){
swap(k[i],k[i+1]);
}
return ;
}
int main()
{
int n,m;
cin>>n>>m;
int k[n],s[n];
for(int i=0;i<n;i++){
cin>>k[i]>>s[i];
}
sort(s,0,n-1,k);
int ret=m*1.5;
while(s[ret-1]==s[ret]){
ret++;
}
//重点是可能循环一次并不能将顺序排正
//其实现在想想,可以只对成绩重复那些人进行一次冒泡排序即可
int key=1;
while(key){
for(int i=0;i<ret;i++){
if(s[i]==s[i+1]&&k[i]>k[i+1]){
for(i;i<ret;i++){
if(s[i]==s[i+1]){
sort2(s,k,i);
i=r;
}
}
break;
}
if(i==ret-1){
key=0;
}
}
}
cout<<s[ret-1]<<" "<<ret<<endl;
for(int i=0;i<ret;i++){
cout<<k[i]<<" "<<s[i]<<endl;
}
return 0;
}
原文地址:https://www.cnblogs.com/lijiahui-123/p/12320921.html