【问题描述】

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

  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
共一行,为被录取同学的编号,按照升序输出。

【输入样例】

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

【输出样例】

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

【数据说明】

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

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

  1. /*
  2. ID: ringxu97
  3. LANG: C++
  4. TASK: class
  5. SOLUTION: 模拟
  6. */
  7. #include<cstdio>
  8. #include<cstring>
  9. #include<iostream>
  10. #include<cmath>
  11. #include<cstdlib>
  12. #include<algorithm>
  13. #include<vector>
  14. #include<stack>
  15. #include<queue>
  16. using namespace std;
  17. const int maxn=100+10;
  18. int n,x,y;
  19. struct STU//A,B表示两次的分数,mark表示总分,num表示序号
  20. {
  21. int A,B;
  22. int mark;
  23. int num;
  24. void calc(){mark=A*x+B*y;}
  25. }s[maxn];
  26. bool operator < (STU a,STU b)
  27. {
  28. if(a.mark==b.mark)return a.num<b.num;
  29. return a.mark>b.mark;
  30. }
  31. bool hash[maxn];
  32. void read()
  33. {
  34. scanf("%d%d%d",&n,&x,&y);
  35. for(int i=1;i<=n;++i)
  36. {
  37. scanf("%d",&s[i].A);
  38. s[i].num=i;
  39. }
  40. for(int i=1;i<=n;++i)
  41. {
  42. scanf("%d",&s[i].B);
  43. s[i].calc();
  44. //printf("%d mark:%d\n",i,s[i].mark);
  45. }
  46. }
  47. int M;
  48. void solve()
  49. {
  50. s[0].num=s[0].mark=-1;
  51. memset(hash,0,sizeof(hash));
  52. sort(s+1,s+1+n);
  53. for(M=1;M<=15;++M)hash[s[M].num]=1;
  54. for(M=16;M<=n;++M)
  55. {
  56. if(s[M].mark!=s[M-1].mark)break;
  57. //printf("%4d mark:%4d cnt:%4d\n",s[i].num,s[i].mark,cnt);
  58. hash[s[M].num]=1;
  59. }
  60. }
  61. void print()
  62. {
  63. int res[maxn];
  64. int *p=res;
  65. for(int i=1;i<=n;++i)if(hash[i])*(p++)=i;
  66. for(int *i=res;i<p-1;++i)printf("%d ",*i);
  67. printf("%d\n",*(p-1));
  68. }
  69. int main()
  70. {
  71. freopen("class.in", "r", stdin);
  72. freopen("class.out", "w", stdout);
  73. read();//读入数据
  74. solve();//排序
  75. print();//出结果
  76. return 0;
  77. }

【模拟】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使用 selector 自定义控件背景 (以spinner 为例)

    1. 在drawable中设置背景spinner_style.xml 文件  如图: 2. 在 styles.xml 中添加该背景 3. 最后在 spinner 控件添加样式 4.参考 http:// ...

  2. oracle数组学习资料

    --oracle数组,所谓数组就是  字段的 个数,数组应该很有用 --可变数组 declare  type v_ar is varray(10) of varchar2(30);   my_ar v ...

  3. iOS、mac开源项目及库汇总

    原文地址:http://blog.csdn.net/qq_26359763/article/details/51076499    iOS每日一记------------之 中级完美大整理 iOS.m ...

  4. SGU 167.I-country

    时间限制:0.75s 空间限制:65M 题意: 在一个n*m(n,m<=15)的网格中,每个格子有一个值,现在从网格中取出k(k<=n*m)个,保证在选中的格子中从任意一个格子去另外的所有 ...

  5. LA 6856 Circle of digits 解题报告

    题目链接 先用后缀数组给串排好序.dc3 O(n) 二分答案+贪心check 答案的长度len=(n+k-1)/k 如果起点为i长为len串大于当前枚举的答案,i的长度取len-1 从起点判断k个串的 ...

  6. ExtJs 第二章,Ext.form.Basic表单操作

    1.认识Ext.form.Panel表单面板         Ext.form.field.CheckBox 复选框 checkboxfield Ext.form.CheckBoxGroup 复选框组 ...

  7. 1. mybatis批量插入数据

    通过list <insert id="saveByList" useGeneratedKeys="true" parameterType="ja ...

  8. 关于浮动float属性和position:absolute属性的区别

    最近返回头看了很多书籍,一直在纠结float属性和absolute绝对定位的区别和使用的情况,给大家分享一下自己的心得和体会吧. 1,float属性 float属性意义是让元素拜托独占一行的霸道总裁, ...

  9. 将listBox中信息显示在dataGridview中,操作datagridview后删除listBox信息和SQL数据库信息 续(浅谈listBox..)

    应用场景      对datagridview控件使用了解,以及操作datagridview选中的信息删除,并且有二次确认后才删除用户信息.相应的删除listbox中用户信息,下面一起看看需要哪些准备 ...

  10. Android 内核基本知识

    Android基本知识 Android基本知识.... 1 1. 各版本系统特性.... 1 2. View绘制流程.... 2 3. 动画体系.... 2 4. 事件分发机制.... 3 输入消息获 ...