原题

韦神提供的思路orz

首先一个显然的性质,所有的c可以提出来,方程变成ax^2+bx的形式

因为x的值是离散的,而m的值又不大

所以一开始让x都为1(注意!x是正整数),然后每次挑一个x让他加一

这样做怎么保证正确?

注意二次函数的性质,由于a>=1,当x递增时斜率,函数值的变化量是递增的

可以贪一个

每次去变化率最小的那个方程,让它的x加一

现在不取,后边也不会更优,所以正确

变化率相同时并不需要比较函数形状

因为由变化率递增的性质,就算取了较坏的函数,下一步还是取较好函数的相同变化量,然后再下一步必定会取到较好函数

代码:

 #include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
#define LL long long
int rd(){int z=,mk=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-')mk=-; ch=getchar();}
while(ch>=''&&ch<=''){z=(z<<)+(z<<)+ch-''; ch=getchar();}
return z*mk;
}
struct nds{LL x; int y;}hp[]; int sz=;
int n,m;
LL a[],b[],c[];
int d[];
LL cclt(LL x,int y){
return x*x*a[y]+x*b[y];
}
void ist(nds x){
hp[++sz]=x;
for(int i=sz;i> && hp[i].x<hp[i>>].x;i>>=) swap(hp[i],hp[i>>]);
}
void pp(){
swap(hp[],hp[sz--]);
for(int i=;;){
int mn=hp[i].x,mnid=i;
if((i<<)<=sz && hp[i<<].x<mn) mn=hp[i<<].x,mnid=(i<<);
if((i<<|)<=sz && hp[i<<|].x<mn) mn=hp[i<<|].x,mnid=(i<<|);
if(i==mnid) break;
swap(hp[i],hp[mnid]);
i=mnid;
}
}
void prvs(){
sz=;
}
int main(){
//freopen("ddd.in","r",stdin);
while(scanf("%d%d",&n,&m)!=EOF){
prvs();
for(int i=;i<=n;++i) a[i]=rd(),b[i]=rd(),c[i]=rd();
LL bwl=;
for(int i=;i<=n;++i){
d[i]=;
ist((nds){cclt(d[i]+,i)-cclt(d[i],i),i});
bwl+=cclt(d[i],i)+c[i];
}
for(int i=n+;i<=m;++i){
LL mn=hp[].x; int mnid=hp[].y;
++d[mnid];
pp();
ist((nds){cclt(d[mnid]+,mnid)-cclt(d[mnid],mnid),mnid});
bwl+=mn;
}
printf("%lld\n",bwl);
}
return ;
}

【2019中国大学生程序设计竞赛-女生专场】C - Function的更多相关文章

  1. 2019中国大学生程序设计竞赛-女生专场(重现赛)部分题解C-Function(贪心+优先队列) H-clock(模拟)

    Function 题目链接 Problem Description wls 有 n 个二次函数 Fi(x) = aix2 + bix + ci (1 ≤ i ≤ n). 现在他想在∑ni=1xi = ...

  2. 2017中国大学生程序设计竞赛 - 女生专场 Deleting Edges(思维+最短路)

    Deleting Edges Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) ...

  3. 2017中国大学生程序设计竞赛 - 女生专场 Happy Necklace(递推+矩阵快速幂)

    Happy Necklace Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) ...

  4. 2017中国大学生程序设计竞赛 - 女生专场(Graph Theory)

    Graph Theory Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)To ...

  5. 2017中国大学生程序设计竞赛 - 女生专场(dp)

    Building Shops Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) To ...

  6. HDU 6024(中国大学生程序设计竞赛女生专场1002)

    这是CCPC女生专场的一道dp题.大佬们都说它简单,我并没有感到它有多简单. 先说一下题意:在一条直线上,有n个教室,现在我要在这些教室里从左到右地建设一些作为糖果屋,每个教室都有自己的坐标xi 和建 ...

  7. "巴卡斯杯" 中国大学生程序设计竞赛 - 女生专场

    Combine String #include<cstdio> #include<cstring> #include<iostream> #include<a ...

  8. hdu_5705_Clock("巴卡斯杯" 中国大学生程序设计竞赛 - 女生专场)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=5705 题意:给你一个时间和一个角度,问你下一个时针和分针形成给出的角度是什么时候 题解:我们可以将这个 ...

  9. hdu_5707_Combine String("巴卡斯杯" 中国大学生程序设计竞赛 - 女生专场)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=5707 题意:给你三个字符串 a,b,c,问你 c能否拆成a,b,a,b串的每一个字符在c中不能变 题解 ...

随机推荐

  1. python基础知识(属性property)

    属性property property               !=          类属性和实例属性 访问计算后所得的值           返回所存储的值 创建用于计算的属性 @proper ...

  2. Unity3D热更新之LuaFramework篇[10]--总结篇

    背景 19年年初的时候,进到一家新单位,公司正准备将现有的游戏做成支持热更的版本.于是寻找热更方案的任务就落在了我头上. 经过搜索了解,能做Unity热更的方案是有好几种,但是要么不够成熟,要么不支持 ...

  3. 关于bootstrap的响应式插件respond.min.js在IE8下出现:拒绝访问。respond.min.js,行: 5,列: 746报错问题

    本地在IE8浏览器下测试兼容性的时候,出现了以下的报错: 该问题在bootstrap的官网有介绍:https://v3.bootcss.com/getting-started

  4. sass与less对比学习

    参考链接:https://blog.csdn.net/luluan_lin/article/details/83749176

  5. web安全问题总结

    主要问题 SQL注入:即通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令,从而获取不该获取的数据 跨站脚本攻击(也称为XSS):指利用网站漏 ...

  6. Transformer详解

    0 简述 Transformer改进了RNN最被人诟病的训练慢的缺点,利用self-attention机制实现快速并行. 并且Transformer可以增加到非常深的深度,充分发掘DNN模型的特性,提 ...

  7. Linux命令---ln、readlink

    ln 无参数--------创建硬链接 -s  -------------创建软链接 用法:ln  [option]  源文件  目标文件 ln test.txt test_hard.txt 只有在同 ...

  8. php 简单的 单例模式

    php单例模式简单说明 使用注意事项:     1.使用时不能用反射模式创建单例,否则会实例化一个新的对象     2.使用懒单例模式时注意线程安全问题     3.饿单例模式和懒单例模式构造方法都是 ...

  9. 1-python django的创建

    一.Virtualenv(我的python环境是3.7) 1.虚拟环境创建(针对python版本和django的版本不一致的) 输入 pip install virtuallenv ,看到如下信息就是 ...

  10. python *****【异常处理】*****

    try: val = input('请输入数字:') num = int(val) except Exception as e: print('操作异常') # import requests # # ...