【问题描述】

信息班这期的课将要结束了,老师要从现在班上的同学中选出比较优秀的同学进入下一期的学习。而录取标准则是将平时作业和考试一起考虑,综合成绩排在前面的则录取。经过一番思考,老师作了以下的筛选计划:

  1. 设计两个参数x,y,学生总成绩为平时成绩的x%和考试成绩的y%。
  2. 将同学按总成绩排名,招收总成绩在前15的学生,不够15则全部录取。

注:总成绩在第15的如果有多人,则可以被同时录取。

例如:18个人总成绩从大到小依次为95,93,93,88,87,84,80,75,70,68,66,65,60,58,57,57,56,55。那么93,93同为第2名,而88为第4名,57,57同为第15名,都被录取。而56,55则不被录取。

老师因为招生培训的事情很忙,所以现在她把信息班学生的成绩表给了你,希望你能告诉她哪些同学被录取了。

【输入】

输入文件class.in
第一行有三个数N,x,y。表示信息班有N个同学以及参数x,y。
第二行N个数,分别为A1,A2,A3 … AN。Ai表示编号为i的同学的平时成绩。
第三行N个数,分别为B1,B2,B3 … BN。Bi表示编号为i的同学的考试成绩。

【输出】

输出文件class.out
共一行,为被录取同学的编号,按照升序输出。

【输入样例】

18 50 50
0 2 4 6 8 10 12 14 16 18 20 22 24 26 28 30 32 34
35 33 31 29 27 25 23 21 19 17 15 13 11 9 7 5 3 1

【输出样例】

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18

【数据说明】

1<=N<=100
0<=x,y<=100
0<=平时成绩,考试成绩<=100
以上数据皆为整数

分析:简单的结构数据,比较简单的模拟,但是我居然WA了!考试的时候只有90分,因为在处理名次的时候有一个比较常识的地方(可是我不知道),第一名如果有两人并列的话,第三个人是第三名而不是第二名!因为这个细节没有处理好所以最后一个点没有过。另外在处理分数的时候可以避开小数处理,直接乘x,y,这样可以避免小数误差降低编程复杂度。总之简单的模拟题,送分的。下面是AC代码。

/*
ID: ringxu97
LANG: C++
TASK: class
SOLUTION: 模拟
*/
#include<cstdio>
#include<cstring>
#include<iostream>
#include<cmath>
#include<cstdlib>
#include<algorithm>
#include<vector>
#include<stack>
#include<queue>
using namespace std;
const int maxn=100+10;
int n,x,y;
struct STU//A,B表示两次的分数,mark表示总分,num表示序号
{
int A,B;
int mark;
int num;
void calc(){mark=A*x+B*y;}
}s[maxn];
bool operator < (STU a,STU b)
{
if(a.mark==b.mark)return a.num<b.num;
return a.mark>b.mark;
}
bool hash[maxn];
void read()
{
scanf("%d%d%d",&n,&x,&y);
for(int i=1;i<=n;++i)
{
scanf("%d",&s[i].A);
s[i].num=i;
}
for(int i=1;i<=n;++i)
{
scanf("%d",&s[i].B);
s[i].calc();
//printf("%d mark:%d\n",i,s[i].mark);
}
}
int M;
void solve()
{
s[0].num=s[0].mark=-1;
memset(hash,0,sizeof(hash));
sort(s+1,s+1+n);
for(M=1;M<=15;++M)hash[s[M].num]=1;
for(M=16;M<=n;++M)
{
if(s[M].mark!=s[M-1].mark)break;
//printf("%4d mark:%4d cnt:%4d\n",s[i].num,s[i].mark,cnt);
hash[s[M].num]=1;
}
}
void print()
{
int res[maxn];
int *p=res;
for(int i=1;i<=n;++i)if(hash[i])*(p++)=i;
for(int *i=res;i<p-1;++i)printf("%d ",*i);
printf("%d\n",*(p-1));
}
int main()
{
freopen("class.in", "r", stdin);
freopen("class.out", "w", stdout);
read();//读入数据
solve();//排序
print();//出结果
return 0;
}

【模拟】Class 解题报告的更多相关文章

  1. 10.30 NFLS-NOIP模拟赛 解题报告

    总结:今天去了NOIP模拟赛,其实是几道USACO的经典的题目,第一题和最后一题都有思路,第二题是我一开始写了个spfa,写了一半中途发现应该是矩阵乘法,然后没做完,然后就没有然后了!第二题的暴力都没 ...

  2. 2018.10.26NOIP模拟赛解题报告

    心路历程 预计得分:\(100 + 100 + 70\) 实际得分:\(40 + 100 + 70\) 妈妈我又挂分了qwq..T1过了大样例就没管,直到临考试结束前\(10min\)才发现大样例是假 ...

  3. 11.1NOIP模拟赛解题报告

    心路历程 预计得分:\(100 + 100 + 50\) 实际得分:\(100 + 100 + 50\) 感觉老师找的题有点水呀. 上来看T1,woc?裸的等比数列求和?然而我不会公式呀..感觉要凉 ...

  4. 2018.10.17NOIP模拟赛解题报告

    心路历程 预计得分:\(100 + 100 +100\) 实际得分:\(100 + 100 + 60\) 辣鸡模拟赛.. 5min切掉T1,看了一下T2 T3,感觉T3会被艹爆因为太原了.. 淦了20 ...

  5. 2018.10.16 NOIP模拟赛解题报告

    心路历程 预计得分:\(100 + 100 + 20 = 220\) 实际得分:\(100 + 100 + 30 = 230\) 辣鸡模拟赛.. T1T2都是一眼题,T3考验卡常数还只有一档暴力分. ...

  6. 20201115gryz模拟赛解题报告

    写在前面 T1:期望100pts,实际0pts(7:50 ~ 8:50 T2:期望0pts,实际0pts(10:00 ~ 10:35 T3:期望20pts,实际40pts( 9:10 ~ 10:00, ...

  7. 20201102gryz模拟赛解题报告

    简述我的苦逼做题经历 考的是NOIP2017day1原题, 开始看到小凯的疑惑时感觉特水,因为这题初中老师讲过, 很nice的秒切 T2发现是个大模拟,虽然字符串不太会用,但起码题意很好理解 边打代码 ...

  8. 20201101gryz模拟赛解题报告

    写在前面 2020rp++ 停课的第一场模拟赛 拿上一年的上一年的day1来考的, 结果得分期望220pts,实际135pts,rank3,太菜了 考着考着机房灯突然灭了,当时慌的一批 以为断电代码要 ...

  9. 20161022 NOIP模拟赛 解题报告

     好元素 [问题描述] 小A一直认为,如果在一个由N个整数组成的数列{An}中,存在以下情况: Am+An+Ap = Ai (1 <= m, n, p < i <= N ,  m,n ...

  10. 【模拟赛】BYVoid魔兽世界模拟赛 解题报告

    题目名称(点击进入相关题解) 血色先锋军 灵魂分流药剂 地铁重组 埃雷萨拉斯寻宝 源文件名(.c/.cpp/.pas) scarlet soultap subway eldrethalas 输入文件名 ...

随机推荐

  1. Android之获取本地图片并压缩方法

    这两天在做项目时,做到上传图片功能一块时,碰到两个问题,一个是如何获取所选图片的路径,一个是如何压缩图片,在查了一些资料和看了别人写的后总算折腾出来了,在此记录一下. 首先既然要选择图片,我们就先要获 ...

  2. CentOS 6.5 64位,调整分区大小

    调整硬盘分区大小 想增加root空间,减少home空间. 1.查看硬盘使用情况. [root@npm ~]# df -h Filesystem Size Used Avail Use% Mounted ...

  3. How to Make LastPass Even More Secure with Google Authenticator

    Google Authenticator LastPass supports Google Authenticator, which is officially available as an app ...

  4. eclipse build很慢的时候,有可能是js文件编译验证慢的问题

    第一步: 去除eclipse的JS验证: 将windows->preference->Java Script->Validator->Errors/Warnings-> ...

  5. Relative与Absolute组合使用

    小伙伴们学习了绝对定位的方法:使用position:absolute可以实现被设置元素相对于浏览器(body)设置定位以后, 大家有没有想过可不可以相对于其它元素进行定位呢?答案是肯定的,当然可以.使 ...

  6. php中文乱码

    一.         首先是PHP网页的编码 1.     php文件本身的编码与网页的编码应匹配 a.     如果欲使用gb2312编码,那么php要输出头:header(“Content-Typ ...

  7. 第六篇、WebSphere8.5 (商业级服务器)大规模集群

    一.前言 上一篇中讲述了WebSphere的安装与应用,该版本的WAS一般都用于开发测试(有些小应用生产环境下也会用到),在生产中绝大部份使用的WebSphere Application Server ...

  8. (转载)css垂直水平居中的整理

    方法一 .demo1 { width:180px; height:180px; line-height:180px; *font-size:160px; border:1px solid #ddd; ...

  9. Asp.net 实现图片缩放 无水印(方法二)

    public static System.Drawing.Image GetImage(string path) { try { if (path.StartsWith("http" ...

  10. InvalidArgument=Value of '1' is not valid for 'index'

    用ListView实现点击ListView的项删除该项的效果,调用ItemSelectionChanged事件. 代码如下: private void listView1_ItemSelectionC ...