【t076】竞赛排名
Time Limit: 1 second
Memory Limit: 128 MB
【问题描述】
某市组织了一次中学生科技全能竞赛,每个选手要参加数学、物理、化学、天文、地理、生物、计算机和英语共八项竞赛。最后综合八项竞赛的成绩排出总名次。选手编号依次为:1,2…N(N为参赛总人数)。 排名规则如下:
1总位置分高的选手名次在前: 2若两个或两个以上的选手总位置分相同,则总分高的选手名次在前: 3若两个或两个以上的选手总位置分和总分均相同,则编号在前的选手名次在前。 请你为竞赛组委会编一程序,计算本次全能竞赛的总排名情况。
【输入格式】
输入文件为compe.in。文件的第一行为参赛总人数N(1<=n<=1000) ,从第二行到第N行依次为编号为1到编号为N的选手的成绩,每行有8个0~100
之间的整数,代表该选手的8项竞赛成绩 。同一行相邻两个数之间用一个空格符隔开。
【输出格式】
输出文件为compe.out.文件有N行,从第1行到第N行依次为排名第1的选手的编号,排名第2的选手的编号,…,排名第N的选手
的编号。
Sample Input
3
72 82 73 68 95 86 82 90
72 90 50 60 80 70 65 80
72 82 73 68 95 86 82 90
Sample Output
1
3
2
【题目链接】:http://noi.qz5z.com/viewtask.asp?id=t076
【题解】
按照所给的公式做就好了;
不会很复杂;
然后在cmp里面改一下排序的依据;
sort的cmp很方便的;想咋排就咋排;
【完整代码】
#include <cstdio>
#include <algorithm>
using namespace std;
struct abc
{
int b[9],sum,bianhao;
double avg,weizhi[9],zongweizhi;
};
int n;
abc a[1010];
double avg[9],temp[9];
bool cmp(abc a,abc b)
{
if (a.zongweizhi > b.zongweizhi)
return true;
else
if (a.zongweizhi == b.zongweizhi && a.sum > b.sum)
return true;
else
if (a.zongweizhi == b.zongweizhi && a.sum == b.sum)
return a.zongweizhi < b.zongweizhi;
return false;
}
int main()
{
//freopen("F:\\rush.txt","r",stdin);
scanf("%d",&n);
for (int i = 1;i <= n;i++)
{
a[i].sum = 0;
a[i].bianhao = i;
for (int j = 1;j <= 8;j++)
{
scanf("%d",&a[i].b[j]);
a[i].sum+=a[i].b[j];
avg[j] += a[i].b[j];
}
}
for (int j = 1;j <= 8;j++)
avg[j]/=n;
for (int i = 1;i <= n;i++)
for (int j = 1;j <= 8;j++)
{
double temp3 = a[i].b[j]-avg[j];
if (temp3<0)
temp3 = -temp3;
temp[j] += temp3;
}
for (int j = 1;j <= 8;j++)
temp[j]/=n;
for (int i = 1;i <= n;i++)
for (int j = 1;j <= 8;j++)
if (temp[j] == 0)
a[i].weizhi[j] = 0;
else
a[i].weizhi[j] = (a[i].b[j]-avg[j])/temp[j];
for (int i = 1;i <= n;i++)
{
double temp = 0,temp1 = 0;
for (int j = 1;j <= 3;j++)
temp += a[i].weizhi[j];
for (int j = 4;j <= 8;j++)
temp1+=a[i].weizhi[j];
temp1*=0.8;
a[i].zongweizhi = temp+temp1;
}
sort(a+1,a+1+n,cmp);
for (int i= 1;i <= n;i++)
printf("%d\n",a[i].bianhao);
return 0;
}
【t076】竞赛排名的更多相关文章
- [ACM_数据结构] 竞赛排名
比赛排名 Time Limit:1000MS Memory Limit:32768K Description: 欢迎参加浙江工业大学“亚信联创杯”程序设计大赛,本次竞赛采用与 ACM/ICPC 相同 ...
- 山东省第四届ACM大学生程序设计竞赛解题报告(部分)
2013年"浪潮杯"山东省第四届ACM大学生程序设计竞赛排名:http://acm.upc.edu.cn/ranklist/ 一.第J题坑爹大水题,模拟一下就行了 J:Contes ...
- 03day2
03day1 不说了,图论题因为没有把加边的过程放到循环里导致只有 10 分.(不要吐槽我啊...) 竞赛排名 排序 [问题描述] [输入] 文件的第一行为参赛总人数 N(1≤N≤1000),从第 ...
- UVa 10258 - Contest Scoreboard
题目大意:关于acm竞赛排名的题目,对于参赛者首先按做出的题目排名,然后是罚时,最后是编号. 多关键字域排序问题. #include <cstdio> #include <cstri ...
- Lavarel artisan 命令
[alex@iZ25c5aeyiiZ yiqizou3.0]# php artisan list Laravel Framework version Usage: command [options] ...
- [Object Tracking] Overview of algorithms for Object Tracking
From: https://www.zhihu.com/question/26493945 可以载入史册的知乎贴 目标跟踪之NIUBILITY的相关滤波 - 专注于分享目标跟踪中非常高效快速的相关滤波 ...
- CTF常见加密方式汇总
1.栅栏密码 在IDF训练营里做过一道关于栅栏密码的问题. 栅栏密码的解法很简单,也有点复杂,字符长度因数多得会有很多个密码.对,栅栏密码的解法就是:计算该字符串是否为合数,若为合数,则求出该合数除本 ...
- NOI1997
T1 竞赛排名 分析:模拟 超级大模拟,太弱了,写个模拟都要2个小时..写的又难看又麻烦..还需努力 var n,i,j,k:longint; t1:real; x,y:..,..] of real; ...
- 场景分割:MIT Scene Parsing 与DilatedNet 扩展卷积网络
MIT Scene Parsing Benchmark简介 Scene parsing is to segment and parse an image into different image re ...
随机推荐
- ASP.NET Core 2.2 十九. 你扔过来个json,我怎么接
原文:ASP.NET Core 2.2 十九. 你扔过来个json,我怎么接 前文说道了Action的激活,这里有个关键的操作就是Action参数的映射与模型绑定,这里即涉及到简单的string.in ...
- 原生js大总结三
021.定义函数的几种方式 1.关键字函数:function fnName(){}; 2.字面量函数:var fn = function(){}; 3.构造函数:var fn = new ...
- SpringMVC,采用的是SpringJDBC
上一次复习搭建了SpringMVC+Mybatis,这次搭建一下SpringMVC,采用的是SpringJDBC,没有采用任何其他的ORM框 架,SpringMVC提供了一整套的WEB框架,所以如果想 ...
- JavaScript字符串替换replace方法
在日常的js开发中, 当要把字符串中的内容替换时,如果使用类似C#的string.replace方法,如下 var str='aabbccaa'; str=str.replace('aa','dd') ...
- js课程 5-13 js事件绑定和鼠标事件注意事项有哪些
js课程 5-13 js事件绑定和鼠标事件注意事项有哪些 一.总结 一句话总结:js代码的灵魂就是改变标签的属性和样式,就这两种. 1.js触发改的东西是哪两样? 属性和样式 2.js如何让页面用标 ...
- 9.4 Binder系统_驱动情景分析_服务使用过程
5. 服务使用过程 test_client进程: 用户态: (1)已结获得了“hello”服务,handle=1; (2)构造数据:code(那个函数)和函数参数 (3)发送ioctl后进入内核态,先 ...
- WCF 设计和实现服务协定(01)
作者:jiankunking 出处:http://blog.csdn.net/jiankunking WCF 术语: • 消息 – 消息是一个独立的数据单元,它可能由几个部分组成,包含消息正文和消息头 ...
- Remove Duplicates from Sorted Array [Python]
Given a sorted array, remove the duplicates in place such that each element appear only once and ret ...
- fatal error C1859的有效解决办法
作者:朱金灿来源:http://blog.csdn.net/clever101 在服务器(操作系统为Widows Server2008)上使用VS C++2008编译工程,总是出现这样一个错误:fat ...
- 开源分享三(炫酷的Android Loading动画)
开源分享三(炫酷的Android Loading动画) 分享GitHub上的一些Loading,为了提升产品用户体验,一个好的Loading必然是不可缺少的,对于一些耗时需要用户等待的页面来说会转移用 ...