分数线划定C++

题目:


解法:

一. 下标数组:

代码:

cpp 复制代码
​
#include<bits/stdc++.h>//万能头文件
using namespace std;
int i,n,m,f,k[5001],s[5001],sub[5001];//f是分数线,sub是下标
bool cmp(int a,int b){//sort规则
    if(s[a]==s[b])return k[a]<k[b];//成绩相等比编号
    return s[a]>s[b];//否则比成绩
}
int main(){
    cin>>n>>m;
    for(i=1;i<=n;i++)cin>>k[sub[i]=i]>>s[i];//输入编号和成绩,同时初始化下标
    sort(sub+1,sub+n+1,cmp);//对下标排序
    f=s[sub[int(m*1.5)]];//算分数线
    for(i=1;s[sub[i]]>=f;i++);//算录取人数
    cout<<f<<" "<<i-1<<endl;
    for(i=1;s[sub[i]]>=f;i++)cout<<k[sub[i]]<<" "<<s[sub[i]]<<endl;//输出
}

​

二. 结构体(struct)和快排函数(sort) :

先来说说结构体:

__ 结构体 __ (struct)是c++中的一个利器,相当于自己定义一个具有多种不同元素的变量(或数组)

结构体中的变量同普通变量,都可以直接使用(只不过结构体的变量要通过"."使用

然后,这道题我们这样可以引用结构体:

cpp 复制代码
struct mark{  //表示每一个面试者
       a,h;   //a表示成绩,h表示号码;
};
mark mian[5000];  
//5000是极限数据,再提一句,也可以定义结构体数组

接着,让我们来讲一讲快排(sort) sort函数包含在STL里,引用它需要头文件algorithm

并且sort可以排序结构体数组

怎么排呢

首先我们需要一个排序的规则:

cpp 复制代码
struct mark{
       int a,h;
};//这是之前的结构体

bool cmp(mark x,mark y) 
//由此可见,结构体变量同样可以用于函数中
{
     if(x.a>y.a) return 1;//x的分数比y大,返回真
    if(x.a==y.a&&x.h<y.h) return 1;
    //x的分数与y一样,但x的号数比y小,返回真
    return 0;     //都不满足,返回假
}

注:如果cmp返回真则x在y前,返回假则y在x前

代码:

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
struct mark{
       int a,h;
};
mark mian[5000];
bool cmp(mark x,mark y)
{
    if(x.a>y.a) return 1;
	if(x.a==y.a&&x.h<y.h) return 1;
    return 0;  
}
int main()
{
    int n,m,pass,s=0;
    cin>>n>>m; 
    //输入考试人数与预计通过人数
    
    for(int i=0;i<n;i++)
    {
        cin>>mian[i].h>>mian[i].a;
        //循环,输入考试者的成绩与号数
    }
    
    sort(mian,mian+n,cmp);     
    //根据分数与号数排序
	pass=mian[m*3/2-1].a;      //计算分数线
    for(int i=0;i<n;i++)
    {
    	if(stu[i].a>=pass) s++;//计算通过人数
	}
	
	cout<<pass<<" "<<s<<endl;
	for(int i=0;i<s;i++)        //输出通过总人数 
        cout<<mian[i].h<<"   "<<mian[i].a<<endl;
    return 0;                   //好习惯
}
相关推荐
螺旋天光极锐斩空闪壹式!几秒前
自制游戏:监狱逃亡
c++·游戏
Thomas_Cai1 分钟前
Python后端flask框架接收zip压缩包方法
开发语言·python·flask
霍先生的虚拟宇宙网络3 分钟前
webp 网页如何录屏?
开发语言·前端·javascript
温吞-ing5 分钟前
第十章JavaScript的应用
开发语言·javascript·ecmascript
魔道不误砍柴功12 分钟前
实际开发中的协变与逆变案例:数据处理流水线
java·开发语言
鲤籽鲲20 分钟前
C# MethodTimer.Fody 使用详解
开发语言·c#·mfc
亚图跨际23 分钟前
Python和R荧光分光光度法
开发语言·python·r语言·荧光分光光度法
Rverdoser31 分钟前
RabbitMQ的基本概念和入门
开发语言·后端·ruby
dj244294570735 分钟前
JAVA中的Lamda表达式
java·开发语言
工业3D_大熊1 小时前
3D可视化引擎HOOPS Luminate场景图详解:形状的创建、销毁与管理
java·c++·3d·docker·c#·制造·数据可视化