【GDOI2018模拟7.9】期末考试
题目
分析
如果我们确定最后的成绩公布日期t,那么就可以贪心来求出最小的不愉快度:
首先,那些希望的日期小于t的同学,会产生不愉快度,这个用前缀和可以来处理,
对于课程,我们要将大于t的课程全部拖到t,
可以考虑有A、B操作,
首先我们知道,操作的总数是固定的
当A>=B时,尽量选B会最优,于是,对于将大于t的课程全部用B操作拖到t。
当A<=B时,尽量选A会最优,那么由于A有数量限制,所以剩下的选B。
这些就可以用前缀和来处理(笨菜鸟无知,用了权值线段树)。
这个贪心的时间复杂度为O(1)。
所以枚举t即可。
另:
由于t的最优值为单峰函数,也可以用三分。
#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
const long long maxlongint=2147483647;
const int mo=1000000007;
const int N=100000;
using namespace std;
long long ss[N*6][2],a,b,c,si[N*6][2],ans=maxlongint*maxlongint;
int n,m,tot;
void put(int v,int l,int r,int x,int y)
{
if(l==r)
{
si[v][y]++;
ss[v][y]+=x;
return;
}
int mid=(l+r)/2;
if(x<=mid) put(v*2,l,mid,x,y);
else put(v*2+1,mid+1,r,x,y);
ss[v][y]=ss[v*2][y]+ss[v*2+1][y];
si[v][y]=si[v*2][y]+si[v*2+1][y];
}
long long find(int v,int l,int r,int x,int y,int z)
{
if(x>y) return 0;
if(l==x && y==r)
{
return ss[v][z];
}
int mid=(l+r)/2;
if(y<=mid) return find(v*2,l,mid,x,y,z);
else
if(x>mid) return find(v*2+1,mid+1,r,x,y,z);
else
return find(v*2,l,mid,x,mid,z)+find(v*2+1,mid+1,r,mid+1,y,z);
}
long long finds(int v,int l,int r,int x,int y,int z)
{
if(x>y) return 0;
if(l==x && y==r)
{
return si[v][z];
}
int mid=(l+r)/2;
if(y<=mid) return finds(v*2,l,mid,x,y,z);
else
if(x>mid) return finds(v*2+1,mid+1,r,x,y,z);
else
return finds(v*2,l,mid,x,mid,z)+finds(v*2+1,mid+1,r,mid+1,y,z);
}
long long get(long long t)
{
long long xx=finds(1,1,N,1,t-1,0)*t-find(1,1,N,1,t-1,0);
if(xx && ans/xx<=c) return maxlongint*maxlongint;
long long sum=xx*c;
if(b<=a)
{
sum+=(find(1,1,N,t+1,N,1)-finds(1,1,N,t+1,N,1)*t)*b;
}
else
{
long long zy=finds(1,1,N,1,t-1,1)*t-find(1,1,N,1,t-1,1),be=find(1,1,N,t+1,N,1)-finds(1,1,N,t+1,N,1)*t;
if(zy>=be) sum+=be*a;
else
{
sum+=zy*a+b*(be-zy);
}
}
return sum;
}
int main()
{
scanf("%lld%lld%lld%d%d",&a,&b,&c,&n,&m);
for(int i=1,x;i<=n;i++)
{
scanf("%d",&x);
put(1,1,N,x,0);
}
for(int i=1,x;i<=m;i++)
{
scanf("%d",&x);
put(1,1,N,x,1);
}
for(int i=1;i<=N;i++) ans=min(ans,get(i));
printf("%lld",ans);
}
【GDOI2018模拟7.9】期末考试的更多相关文章
- python期末考试复习
期末考试复习 补修的python跟着大一一起学,考试肯定不会出难,于是就敲了一些代码,把他们放到博客上,来记录一下 代码都是一段一段的,且python代码不是很多,所以我都写到了一个文件里,作为练习 ...
- 复旦大学2015--2016学年第二学期高等代数II期末考试情况分析
一.期末考试成绩班级前几名 胡晓波(90).杨彦婷(88).宋卓卿(85).唐指朝(84).陈建兵(83).宋沛颖(82).王昊越(81).白睿(80).韩沅伯(80).王艺楷(80).张漠林(80) ...
- 复旦大学2014--2015学年第二学期(14级)高等代数II期末考试第八大题解答
八.(本题10分) 设 $A,B$ 为 $n$ 阶半正定实对称阵, 求证: $AB$ 可对角化. 分析 证明分成两个步骤: 第一步, 将 $A,B$ 中的某一个简化为合同标准形来考虑问题, 这是矩 ...
- 复旦大学2015--2016学年第一学期高等代数I期末考试情况分析
一.期末考试成绩班级前几名 胡晓波(93).宋沛颖(92).张舒帆(91).姚人天(90).曾奕博(90).杨彦婷(90).白睿(88).唐指朝(87).谢灵尧(87).蔡雪(87) 二.总成绩计算方 ...
- 复旦大学2014--2015学年第二学期高等代数II期末考试情况分析
一.期末考试成绩班级前几名 钱列(100).王华(92).李笑尘(92).金羽佳(91).李卓凡(91).包振航(91).董麒麟(90).张钧瑞(90).陆毕晨(90).刘杰(90).黄成晗(90). ...
- 复旦大学2014--2015学年第一学期高等代数I期末考试情况分析
一.期末考试成绩班级前几名 金羽佳(92).包振航(91).陈品翰(91).孙浩然(90).李卓凡(85).张钧瑞(84).郭昱君(84).董麒麟(84).张诚纯(84).叶瑜(84) 二.总成绩计算 ...
- nyoj 757 期末考试【优先队列+贪心】
期末考试 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 马上就要考试了,小T有许多作业要做,而且每个老师都给出来了作业要交的期限,如果在规定的期限内没 交作业就会扣 ...
- 复旦大学2016--2017学年第一学期高等代数I期末考试情况分析
一.期末考试成绩班级前十名 宁盛臻(100).朱民哲(92).徐钰伦(86).范凌虎(85).沈伊南(84).何陶然(84).丁知愚(83).焦思邈(83).董瀚泽(82).钱信(81) 二.总成绩计 ...
- 2012 B 中国近现代史纲要》课程期末考试试卷
湖南人文科技学院2013年3月公共课 2011级<中国近现代史纲要>课程期末考试试卷B 考核方式:(开卷) 考试时量: ...
- 2012 A 《中国近现代史纲要》课程期末考试试卷
湖南人文科技学院2012—2013学年第1学期公共课 2011级<中国近现代史纲要>课程期末考试试卷 考核方式:(开卷) ...
随机推荐
- 【Linux开发】linux设备驱动归纳总结(四):1.进程管理的相关概念
linux设备驱动归纳总结(四):1.进程管理的相关概念 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ...
- 最大熵马尔科夫模型(MEMM)及其标签偏置问题
定义: MEMM是这样的一个概率模型,即在给定的观察状态和前一状态的条件下,出现当前状态的概率. Ø S表示状态的有限集合 Ø O表示观察序列集合 Ø Pr(s|s’,o):观察和状态转移概 ...
- 关于Linux文本处理“三剑客”的一些小操作。
Linux文本处理“三剑客”,即grep.sed.awk,这是Linux中最核心 的3个命令. 一.首先做个简单的介绍: 1.awk:linux三剑客老大,过滤,输出内容,一门语言.NR代表行号. 2 ...
- 2-SAT问题介绍求解 + 模板题P4782
(点击此处查看原题) 什么是2-SAT问题 sat 即 Satisfiability,意思为可满足,那么2-SAT表示一些布尔变量只能取true或者false,而某两个变量之间的值存在一定的关系(如: ...
- Kinect开发-开发环境搭建
0.安装Visual Studio.版本无所谓,但Kinect SDK for Windows只支持C/C#.接下来的开发语言将使用C#,用户界面框架使用WPF. 安装Kinect SDK for W ...
- linux连接Windows系统之项目连接
在桥接模式下 在linux内需要设置 防火墙关闭 在Windows中连接 linux的ip连接 ***项目 在linux中命令行输入setup-->防火墙配置-->空格-->确定-- ...
- Spring 中的bean 是线程安全的吗?
结论: 不是线程安全的 Spring容器中的Bean是否线程安全,容器本身并没有提供Bean的线程安全策略,因此可以说Spring容器中的Bean本身不具备线程安全的特性,但是具体还是要结合具体sco ...
- nginx配置一般优化参数
#user nobody; worker_processes 2; # CPU亲和力,worker_processes最多开启8个,注意写法 worker_cpu_affinity 01 10; wo ...
- redis 学习(5)-- 列表类型
redis 学习(5)-- 列表类型 列表特点 有序.可以重复.左右两边插入弹出 索引相关知识 索引从左往右,从0开始逐个增大 0 1 2 3 4 5 索引从右往左,从-1开始逐个减小 -6 -5 - ...
- 06 Nginx
1.检查linux上是否通过yum安装了nginx rpm -qi nginx 2.解决安装nginx所依赖包 yum install gcc patch libffi-devel python-de ...