(排序)P1068 分数线划定

Posted lijiahui-123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了(排序)P1068 分数线划定相关的知识,希望对你有一定的参考价值。

题解:

需要注意的是,快排完之后并不是按照编号从小到大的顺序输出

#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;
}

以上是关于(排序)P1068 分数线划定的主要内容,如果未能解决你的问题,请参考以下文章

题解 P1068 分数线划定

P1068 分数线划定

洛谷 P1068 分数线划定 题解

1.10编程基础之简单排序_05分数线划定

Luogu 1068 - 分数线划定 - [快速排序]

6.18校内testT2分数线划定