6127:Largest Average
- #include<bits/stdc++.h>
- using namespace std;
- int a[100001];
- double ave[100001];
- struct student{
- int i;
- double ave;
- };
- student stu[100001];
- bool cmp(const student &s1,const student &s2){
- if(s1.ave==s2.ave){
- return s1.i<s2.i;
- }else{
- return s1.ave>s2.ave;
- }
- }
- int main(){
- priority_queue<int,vector<int>,greater<int> > q;
- int n;
- while(cin>>n){
- memset(stu,0,sizeof(student)*n);
- memset(a,0,sizeof(a));
- memset(ave,0,sizeof(ave));
- for(int i=0;i<n;++i){
- scanf("%d",&a[i]);
- }
- double s=0;
- for(int i=n-1;i>0;i--){
- if(i!=n-1){
- if(a[i]<q.top()){ //如果这个数比队列中最小的值还小,算平均值的时候先没放进队列
- int ss=q.size();
- ave[i]=s*1.0/ss;
- stu[i].ave=ave[i];
- stu[i].i=i;
- q.push(a[i]); //最后再放进队列
- }else{ //如果这个数比队列中最小的值大
- q.push(a[i]); //把这个数放进队列
- int x=q.top();
- q.pop(); //把队列中最小的值弹出
- int ss=q.size();
- ave[i]=(s+a[i]-x)*1.0/ss; //算出平均值
- stu[i].ave=ave[i];
- stu[i].i=i;
- q.push(x); //最后把最小的值压回去队列
- }
- }else{
- q.push(a[i]);
- ave[i]=a[i];
- stu[i].ave=ave[i];
- stu[i].i=i;
- }
- s+=a[i];
- //printf("%d %.2f\n",stu[i].i,stu[i].ave);
- }
- sort(stu,stu+n,cmp);
- cout<<stu[0].i;
- for(int i=1;i<n;++i){
- if(stu[i].ave==stu[0].ave&&stu[i].i<=n-2){
- cout<<" "<<stu[i].i;
- }else{
- break;
- }
- }
- while(!q.empty()){
- q.pop();
- }
- cout<<endl;
- }
- }
6127:Largest Average的更多相关文章
- LeetCode之“排序”:Largest Number
题目链接 题目要求: Given a list of non negative integers, arrange them such that they form the largest numbe ...
- Leetcode:Largest Number详细题解
题目 Given a list of non negative integers, arrange them such that they form the largest number. For e ...
- LeetCode第[84]题(Java):Largest Rectangle in Histogram(最大的矩形柱状图)
题目:最大的矩形柱状图 难度:hard 题目内容: Given n non-negative integers representing the histogram's bar height wher ...
- LeetCode OJ:Largest Number(最大数字)
Given a list of non negative integers, arrange them such that they form the largest number. For exam ...
- HDU 5461:Largest Point
Largest Point Time Limit: 1500/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) To ...
- HDU1506: Largest Rectangle in a Histogram(最大子矩阵,好题动态优化左右边界)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1506 刚开始没考虑时间复杂度,直接敲了,直接tle了,之后没有思路,然后看题解,看见大神写的优化非常棒. ...
- POJ2559:Largest Rectangle in a Histogram
浅谈栈:https://www.cnblogs.com/AKMer/p/10278222.html 题目传送门:http://poj.org/problem?id=2559 贪心的想,最大的子矩阵顶部 ...
- AtCoder Grand Contest 009 E:Eternal Average
题目传送门:https://agc009.contest.atcoder.jp/tasks/agc009_e 题目翻译 纸上写了\(N\)个\(1\)和\(M\)个\(0\),你每次可以选择\(k\) ...
- AGC009:Eternal Average
传送门 好神啊 直接考虑一棵 \(n+m\) 个叶子的 \(k\) 叉树,根结点权值为 \(\sum_{i\in m}(\frac{1}{k})^{deep_i}\) 对于一个 \(deep\) 的序 ...
随机推荐
- 风炫安全web安全学习第三十二节课 Python代码执行以及代码防御措施
风炫安全web安全学习第三十二节课 Python代码执行以及代码防御措施 Python 语言可能发生的命令执行漏洞 内置危险函数 eval和exec函数 eval eval是一个python内置函数, ...
- 吃透论文——推荐算法不可不看的DeepFM模型
大家好,我们今天继续来剖析一些推荐广告领域的论文. 今天选择的这篇叫做DeepFM: A Factorization-Machine based Neural Network for CTR Pred ...
- win10中安装Linux子系统
前言 Win10的Linux子系统闻名已久,今天就来操作一下 正文 限制 该功能是win10 1809 及之后才加入的功能,故请先核对版本. 开启功能 打开windows设置 设置 -> 更新和 ...
- C++ 简单输出当前日期时间
根据https://www.runoob.com/cplusplus/cpp-date-time.html编写. 首先介绍2个数据类型. 一个是time_t,与时间函数相关的变量,定义的变量记录着自 ...
- cookie和session会话技术
因为http协议是无状态的,也就是说每个客户端访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端状态.会话技术是帮助服务器记住客户端状态的. 一次会话的开始是通过浏览器访问某个 ...
- mmall商城购物车模块总结
购物车模块的设计思想 购物车的实现方式有很多,但是最常见的就三种:Cookie,Session,数据库.三种方法各有优劣,适合的场景各不相同.Cookie方法:通过把购物车中的商品数据写入Cookie ...
- ClickHouse安装使用(单机、集群、高可用)
Clickhouse版本:20.3.6.40-2 安装包地址:https://repo.yandex.ru/clickhouse/rpm/stable/x86_64/ 一.单机版 1.安装依赖 yum ...
- ORA-00054: 資源正被使用中, 請設定 NOWAIT 來取得它, 否則逾時到期
1.查看被使用资源的OBJECT_ID SELECT *FROM DBA_OBJECTS WHERE OBJECT_NAME='OBJECT_NAME' 2.查看资源被谁占用SELECT * FROM ...
- C++:I/O流的概念和流类库的结构
一.C++输入输出包含以下三个方面的内容: 对系统指定的标准设备的输入和输出.即从键盘输入数据,输出到显示器屏幕.这种输入输出称为标准的输入输出,简称标准I/O. 以外存磁盘文件为对象进行输入和输出, ...
- [Usaco2008 Mar]River Crossing渡河问题
题目描述 Farmer John以及他的N(1 <= N <= 2,500)头奶牛打算过一条河,但他们所有的渡河工具,仅仅是一个木筏. 由于奶牛不会划船,在整个渡河过程中,FJ必须始终在木 ...