1015. 德才论 (25)

本文介绍PAT1015题目的解析,根据宋代史学家司马光的德才理论,对考生的德才分数进行排序,并提供了一种实现思路及代码示例。

题目地址:PAT1015.德才论(25)

题目描述:

宋代史学家司马光在《资治通鉴》中有一段著名的“德才论”:“是故才德全尽谓之圣人,才德兼亡谓之愚人,德胜才谓之君子,才胜德谓之小人。凡取人之术,苟不得圣人,君子而与之,与其得小人,不若得愚人。”

现给出一批考生的德才分数,请根据司马光的理论给出录取排名。

输入格式:

输入第1行给出3个正整数,分别为:N(<=105),即考生总数;L(>=60),为录取最低分数线,即德分和才分均不低于L的考生才有资格被考虑录取;H(<100),为优先录取线——德分和才分均不低于此线的被定义为“才德全尽”,此类考生按德才总分从高到低排序;才分不到但德分到线的一类考生属于“德胜才”,也按总分排序,但排在第一类考生之后;德才分均低于H,但是德分不低于才分的考生属于“才德兼亡”但尚有“德胜才”者,按总分排序,但排在第二类考生之后;其他达到最低线L的考生也按总分排序,但排在第三类考生之后。

随后N行,每行给出一位考生的信息,包括:准考证号、德分、才分,其中准考证号为8位整数,德才分为区间[0, 100]内的整数。数字间以空格分隔。

输出格式:

输出第1行首先给出达到最低分数线的考生人数M,随后M行,每行按照输入格式输出一位考生的信息,考生按输入中说明的规则从高到低排序。当某类考生中有多人总分相同时,按其德分降序排列;若德分也并列,则按准考证号的升序输出。

超时Tips:

    如果出现超时的情况,最简单的处理,大家可以试试把cin、cout改成scanf和printf

程序:

#include <iostream>
#include <algorithm>
#include <vector>

using namespace std;


struct Stu
{
	int sno;
	int DMark;
	int CMark;
	int TotalMark;
};

bool compare(Stu stu1, Stu stu2)
{
	if (stu1.TotalMark > stu2.TotalMark)
	{
		return true;
	}
	else if (stu1.TotalMark == stu2.TotalMark)
	{
		if (stu1.DMark > stu2.DMark)
		{
			return true;
		}
		else if (stu1.DMark == stu2.DMark)
		{
			return stu1.sno <= stu2.sno;
		}
	}
	return false;
}

// printf速度比cout快,用上面这个方法会部分超时
void printStu(vector<Stu> stuMark){  
    for(vector<Stu>::iterator it = stuMark.begin() ; it != stuMark.end() ; it++ )  
    {  
        printf("%d %d %d\n", it->sno, it->DMark, it->CMark);  
    }  
} 

int main()
{
	int N, L, H;
	cin >> N >> L >> H;
	vector <Stu> FriVector, SecVector, ThrVector, FouVector;

	int count = 0;

	for (int i = 0; i < N; ++i)
	{
		int sno, DMark, CMark;
		cin >> sno >> DMark >> CMark;


		if (DMark >= L && CMark >= L)
		{
			count ++;
			Stu student;			
			student.sno = sno;
			student.DMark = DMark;
			student.CMark = CMark;
			student.TotalMark = DMark + CMark;

			if (DMark >= H && CMark >= H)
			{
				FriVector.push_back(student);
			}
			else if (DMark >= H && CMark < H)
			{
				SecVector.push_back(student);
			}
			else if (DMark < H && CMark < H && DMark >= CMark)
			{
				ThrVector.push_back(student);
			}
			else
			{
				FouVector.push_back(student);
			}
		}

	}

	sort(FriVector.begin(), FriVector.end(), compare);
	sort(SecVector.begin(), SecVector.end(), compare);
	sort(ThrVector.begin(), ThrVector.end(), compare);
	sort(FouVector.begin(), FouVector.end(), compare);

	cout << count << endl;
	printStu(FriVector);
	printStu(SecVector);
	printStu(ThrVector);
	printStu(FouVector);
	return 0;
}

下载前可以先看下教程 https://pan.quark.cn/s/a4b39357ea24 在网页构建过程中,表单(Form)扮演着用户与网站之间沟通的关键角色,其主要功能在于汇集用户的各类输入信息。 JavaScript作为网页开发的核心技术,提供了多样化的API和函数来操作表单组件,诸如input和select等元素。 本专题将详细研究如何借助原生JavaScript对form表单进行视觉优化,并对input输入框与select下拉框进行功能增强。 一、表单基础1. 表单组件:在HTML语言中,<form>标签用于构建一个表单,该标签内部可以容纳多种表单组件,包括<input>(输入框)、<select>(下拉框)、<textarea>(多行文本输入区域)等。 2. 表单参数:诸如action(表单提交的地址)、method(表单提交的协议,为GET或POST)等属性,它们决定了表单的行为特性。 3. 表单行为:诸如onsubmit(表单提交时触发的动作)、onchange(表单元素值变更时触发的动作)等事件,能够通过JavaScript进行响应式处理。 二、input元素视觉优化1. CSS定制:通过设定input元素的CSS属性,例如border(边框)、background-color(背景色)、padding(内边距)、font-size(字体大小)等,能够调整其视觉表现。 2. placeholder特性:提供预填的提示文字,以帮助用户明确输入框的预期用途。 3. 图标集成:借助:before和:after伪元素或者额外的HTML组件结合CSS定位技术,可以在输入框中嵌入图标,从而增强视觉吸引力。 三、select下拉框视觉优化1. 复选功能:通过设置multiple属性...
【EI复现】基于深度强化学习的微能源网能量管理与优化策略研究(Python代码实现)内容概要:本文围绕“基于深度强化学习的微能源网能量管理与优化策略”展开研究,重点探讨了如何利用深度强化学习技术对微能源系统进行高效的能量管理与优化调度。文中结合Python代码实现,复现了EI级别研究成果,涵盖了微电网中分布式能源、储能系统及负荷的协调优化问题,通过构建合理的奖励函数与状态空间模型,实现对复杂能源系统的智能决策支持。研究体现了深度强化学习在应对不确定性可再生能源出力、负荷波动等挑战中的优势,提升了系统运行的经济性与稳定性。; 适合人群:具备一定Python编程基础和机器学习背景,从事能源系统优化、智能电网、强化学习应用等相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于微能源网的能量调度与优化控制,提升系统能效与经济效益;②为深度强化学习在能源管理领域的落地提供可复现的技术路径与代码参考;③服务于学术研究与论文复现,特别是EI/SCI级别高水平论文的仿真实验部分。; 阅读建议:建议读者结合提供的Python代码进行实践操作,深入理解深度强化学习算法在能源系统建模中的具体应用,重点关注状态设计、动作空间定义与奖励函数构造等关键环节,并可进一步扩展至多智能体强化学习或与其他优化算法的融合研究。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值