HDU 1084 [What Is Your Grade?] 结构体排序

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1084

题目大意:共5道题,N个学生。做出5道满分,0道50分。做出1—4道的同学,若在前50%(向下取整),则获得95、85、75、65,若在后50%则获得90、80、70、60.

关键思想:结构体排序

//结构体排序,考虑边界
#include <iostream>
#include <algorithm>
#include <cmath>
#include <memory.h>
using namespace std;

struct node{
	int id;
	int n;
	int h,m,s;
	int score;
}e[102];
int c[6]; //保存做出i题的人数
bool cmps(node a,node b){
	return a.n==b.n?(a.h==b.h?	(a.m==b.m?	a.s<b.s:a.m<b.m):a.h<b.h):a.n>b.n;
}//按题数时间排序
bool cmpid(node a,node b){
	return a.id<b.id;
}//按输入ID顺序排序 

int main(){
	int N,cnt;
	while(cin>>N&&N!=-1){
		memset(e,0,sizeof(e));
		memset(c,0,sizeof(c));
		for(int i=0;i<N;i++){
			e[i].id=i;
			scanf("%d%d:%d:%d",&e[i].n,&e[i].h,&e[i].m,&e[i].s);
			c[e[i].n]++;
		}
		sort(e,e+N,cmps);
		cnt=0;
		for(int j=0;j<c[5];j++){
			e[cnt+j].score=100;
		}
		cnt+=c[5];
		for(int k=4;k>0;k--){
			for(int j=0;j<c[k];j++){
				if(j<c[k]/2)e[cnt+j].score=50+5*(2*k+1);
				else e[cnt+j].score=50+10*k;
			}
			cnt+=(c[k]);
		}
		for(int j=0;j<c[0];j++){
			e[cnt+j].score=50;
		}
		sort(e,e+N,cmpid);
		for(int i=0;i<N;i++)cout<<e[i].score<<endl;
		cout<<endl;
	}
	return 0;
}

  

时间: 2024-10-23 09:15:27

HDU 1084 [What Is Your Grade?] 结构体排序的相关文章

HDU 2409 Team Arrangement (结构体排序)

题目链接:HDU 2409 Team Arrangement 题意:给出22个人(编号,名字,踢的位置,在队里的时间),让我们选DD-MM-SS的阵型+一个守门员.在选出队长(时间在最久的就是队长,时间相同编号大为队长),选人的顺序是从编号小的开始. 结构体排序就好了,注意出输出是按队长,D,M,S的顺序,选队长记录队长的编号(而不是下标,我的代码之后还要排序). AC代码: #include<stdio.h> #include<string.h> #include<algo

hdu 5702 Solving Order(结构体排序 水题)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5702 Solving Order Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 184    Accepted Submission(s): 135 Problem Description Welcome to HDU to take p

hdu 1070(结构体排序)

Milk Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 13639    Accepted Submission(s): 3328 Problem Description Ignatius drinks milk everyday, now he is in the supermarket and he wants to choose

【结构体排序】hdu 2409 Team Arrangement

[结构体排序]hdu 2409 Team Arrangement 题目链接:hdu 2409 Team Arrangement 题目大意 给出22个球员的各种信息,要求按照给出的阵形选择球员和队长共11人: 选择球员的规则是:同角色的球员按照编号从小到大选择,直到选够此角色的人数: 选择队长的规则是:在所有已经被选择为某角色的球员中,选择服役时间最长的那个球员, 如果服役时间时间相同,就选择编号较大的那一个球员: 2006 Asia Regional Tehran(伊朗首都德黑兰)的第一题,题意

HDU 1862 EXCEL排序(结构体排序)

EXCEL排序 Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 16387    Accepted Submission(s): 6137 Problem Description Excel可以对一组纪录按任意指定列排序.现请你编写程序实现类似功能. Input 测试输入包含若干测试用例.每个测试用例的第1行包含两个整数 N (<=1

hdu 1069 Monkey and Banana (结构体排序,也属于简单的dp)

Monkey and Banana Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 7770    Accepted Submission(s): 4003 Problem Description A group of researchers are designing an experiment to test the IQ of a

HDOJ 1009. Fat Mouse&#39; Trade 贪心 结构体排序

FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 56784    Accepted Submission(s): 19009 Problem Description FatMouse prepared M pounds of cat food, ready to trade with the cats g

JustOj 2039: 成绩排名 (结构体排序)

题目描述 每次期末考试成绩出来之前的一段时间大豪哥心里都是痛苦的,总感觉自己会在班上排名特别差.所以当成绩出来以后大豪哥想快点知道班上的总排名,以便知道自己的排名.(PS:大豪哥班上有个学霸名叫日天,又名泰迪,不要问我为什么,因为泰迪的行为决定的) 输入 多组测试数据,至文件结尾.先输入每个班上有n个同学,这个学期有m门课程(1<=n,m<=100)接下来有n行,每行的输入格式为学号id,姓名name,课程成绩k1,课程成绩k2... ,课程成绩km.(学号在int型范围以内,0<=ki

【转】 从最简单的vector中sort用法到自定义比较函数comp后对结构体排序的sort算法

sort函数在使用中非常好用,也非常简单,而且效率与冒泡或者选择排序不是一个数量级.本文就sort函数在vector中的用法分为sort函数入门用法与自定义comp比较函数比较结构体这两个最基本的功能讲讲其用法: 1.sort入门: 使用sort需要包含algorithm头文件,完整代码如下 #include<iostream> #include<vector> #include<algorithm>//貌似可以不用,但最好加上. using namespace std