hdnoip2017
T1:
小喵喵有 n 个小鱼干排成一列,其中第 i个小鱼干有两种属性,美味度 ai 和特殊度 bi
现在小喵喵要吃掉一些小鱼干,出于一些原因,小喵喵会吃掉连续的一段区间中的所有小鱼干。
如果吃掉了 [l,r]一段区间,那么小喵喵会获得一些满意度。
形式化地,总满意度 =(ai,l<=i<=r)×(1+bi,l<=i<=r)
由于只有小喵喵最喜欢的小鱼干的特殊度等于 11,所以 bi=1 的小鱼干数量不会超过 400个,其他的 bi=0
现在小喵喵可以选择任意一段区间(不能为空),但是有一些小鱼干的美味度是负数,吃掉所有小鱼干不一定会获得最多的满意度。所以小喵喵想知道最大能获得的总满意度是多少。
思路:
模拟+优化
首先可以想到n*n的模拟,但是复杂度过高于是我们想到:
可以在每个bi等于1的点预处理一个数组,表示这个点向左最大能延伸到多少
这样我们在枚举每个点的时候就只需要枚举在它之前有多少个bi为1的点就可以了
但是只是这样还是有问题的,如果最大值是不经过任何一个bi为1的点结果就是有问题的
所以我们需要再单独跑一遍判断
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
#include<cstdlib>
#include<set>
#include<map>
#include<vector>
#include<stack>
#include<queue>
#define ll long long
#define inf 2147383611
#define MAXN 101010
#define MOD
using namespace std;
inline ll read()
{
ll x=,f=;
char ch;ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-;ch=getchar();}
while(isdigit(ch)) {x=x*+ch-'';ch=getchar();}
return x*f;
}
ll n,a[MAXN],k[MAXN],cnt,sa[MAXN],b[MAXN],ans,m[MAXN],x;
int main()
{
n=read();
for(int i=;i<=n;i++) {a[i]=read();sa[i]=sa[i-]+a[i];}
for(int i=;i<=n;i++) {x=read();b[i]=b[i-]+x;if(x) k[++cnt]=i;}
k[]=,k[cnt+]=n+;
//for(int i=1;i<=cnt+1;i++) cout<<i<<" "<<k[i]<<endl;
ll tmp,_max;
memset(m,-,sizeof(m));
for(int i=;i<=cnt;i++)
{
tmp=,_max=a[k[i]];
for(int j=k[i];j>k[i-];j--)
{
tmp+=a[j];
if(tmp>=_max) {m[i]=j;_max=tmp;}
}
}
//for(int i=1;i<=cnt;i++) cout<<m[i]<<endl;
ll res;
if(b[]) ans=sa[]*b[];
else ans=sa[];
for(int i=;i<=n;i++)
{
if(b[i]) ans=max(ans,sa[i]*b[i]);
else ans=max(sa[i],ans);
for(int j=b[i];j>=;j--)
{
ans=max(ans,(sa[i]-sa[m[j]-])*(b[i]-j+));
//cout<<i<<" "<<j<<" "<<(sa[i]-sa[k[j]-1])*(b[i]-j+2)<<endl;
}
}
for(int i=;i<=cnt+;i++)
{
tmp=-inf;
for(int j=k[i-]+;j<k[i];j++)
{
if(tmp<&&a[j]<=) tmp=max(tmp,a[j]);
if(tmp>=) tmp+=a[j];
if(tmp<&&a[j]>) tmp=a[j];
ans=max(ans,tmp);
//cout<<i<<" "<<j<<" "<<tmp<<endl;
}
}
printf("%lld",ans);
}
T2:
绵羊送给小喵喵了 n 个小鱼干。小喵喵要把它们全部吃掉!
但是绵羊告诉小喵喵要按照某种顺序来吃。
绵羊一共说了 m 条限制,每条限制的格式为 u v,表示要先吃掉 u 号小鱼干之后才能吃 v 号小鱼干。
绵羊保证,这些条限制不会出现循环需求的情况,即一定存在某种顺序使得 n 个小鱼干都被吃掉。
绵羊还允许小喵喵不遵守其中小于等于 k 条限制。
小喵喵想知道在吃完所有的小鱼干的前提下,吃小鱼干的顺序的字典序最小是多少。
两个吃小鱼干的顺序的字典序大小比较即为:首先比较第一个吃的小鱼干,编号较小的字典序较小,若相同,则比较第二个吃的小鱼干,一直比到可以分出大小。
注意到两个顺序一定可以比较大小
思路:
几乎是裸的拓扑排序
只需要记录一下他的入度,判断它的入度是否小于k
即是否可以加到队列前面
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
#include<cstdlib>
#include<set>
#include<map>
#include<vector>
#include<stack>
#include<queue>
#define ll long long
#define inf 2147383611
#define MAXN 152701
#define MOD
using namespace std;
inline ll read()
{
ll x=,f=;
char ch;ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-;ch=getchar();}
while(isdigit(ch)) {x=x*+ch-'';ch=getchar();}
return x*f;
}
int cnt,n,m,k,to[MAXN],first[MAXN],next[MAXN],in[MAXN];
priority_queue <int,vector<int>,greater<int> > q;
bool vis[MAXN],out[MAXN];
void add(int u,int v) {in[v]++,next[++cnt]=first[u],first[u]=cnt,to[cnt]=v;}
int main()
{
n=read(),m=read(),k=read();
int a,b;
while(m--) {a=read(),b=read();add(a,b);}
for(int i=;i<=n;i++)
if(in[i]<=k) {q.push(i);vis[i]=;}
int pos,t;
while(!q.empty())
{
pos=q.top();
q.pop();
vis[pos]=;
if(in[pos]>k) continue;
printf("%d ",pos);
k-=in[pos],out[pos]=;
for(int i=first[pos];i;i=next[i])
{
t=to[i];
if(out[t]) continue;
in[t]--;
if(!vis[t]&&in[t]<=k) {q.push(t);vis[t]=;}
}
}
}
hdnoip2017的更多相关文章
- HDnoip2017题解
那么,作为一名初入信息竞赛的选手,我也试着开始用博客记录自己的学习历程,那么这篇文章先简单介绍一下我自己吧. 本人开始学习信息学大概以来,主要都是用的C++,所以对其他语言并不是十分熟悉.2016我还 ...
- [HDNOIP2017提高组]题解
(送给外省的同学们:HD = 海淀) [HDNOIP201701]小鱼干 试题描述 小喵喵有 n 个小鱼干排成一列,其中第 i 个小鱼干有两种属性,美味度 ai 和特殊度 bi. 现在小喵喵要吃掉一些 ...
随机推荐
- [Python3网络爬虫开发实战] 1.7.1-Charles的安装
Charles是一个网络抓包工具,相比Fiddler,其功能更为强大,而且跨平台支持得更好,所以这里选用它来作为主要的移动端抓包工具. 1. 相关链接 官方网站:https://www.charles ...
- 【转】vfork 和 fork的区别
fork()与vfock()都是创建一个进程,那他们有什么区别呢?总结有以下三点区别: 1. fork ():子进程拷贝父进程的数据段,代码段 vfork ( ):子进程与父进程共享数据段 ...
- linux下硬盘分区、格式化以及文件管理系统
1.添加虚拟硬盘 (1)点击编辑虚拟机位置,然后点击添加 (2)点击添加硬盘 (3)点击下一步 (4)创建新虚拟磁盘并点击下一步 (5)指定磁盘容量并且点击下一步 (6)点击完成 2.系统分区 当 ...
- 什么是CPU密集型、IO密集型?(转发)
CPU密集型(CPU-bound) CPU密集型也叫计算密集型,指的是系统的硬盘.内存性能相对CPU要好很多,此时,系统运作大部分的状况是CPU Loading 100%,CPU要读/写I/O(硬盘/ ...
- java项目连接access数据库
1.导入Access_JDBC30.jar到项目中 jar包百度云链接:https://pan.baidu.com/s/10HFM3HomMArvfHjklA_1MA 密码:0qxp 项目名称-> ...
- Python文件处理(txt、csv文件读取)
打开文件 使用Python内置的方法 open()可以打开文件 file object = open(file_name [, access_mode][, buffering]) file_name ...
- 九度oj 题目1060:完数VS盈数
题目1060:完数VS盈数 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:6461 解决:2426 题目描述: 一个数如果恰好等于它的各因子(该数本身除外)子和,如:6=3+2+1.则称其 ...
- ajax异步获取数据后动态向表格中添加数据(行)
因为某些原因,项目中突然需要做自己做个ajax异步获取数据后动态向表格中添加数据的页面,网上找了半天都没有 看到现成的,决定自己写个例子 1.HTML页面 <!doctype html> ...
- scp远程文件传输
第一次.提示下载公钥 [root@rhel5 ~]# scp install.log root@192.168.124.129:/tmp The authenticity of host '192.1 ...
- 在mysql数据库中,文章表设计有啥好的思路
Q: 用mysql设计一张文章表,不知道有啥好的思路! 我是这样的,应为考虑附件和图片,所以我的文章表除了有varchar(1000)的文章内容,还设置了个Bolb接收附件和图片. 我用的是mysql ...