LOJ 模拟赛
1.LOJ 507 接竹竿
dp[i]表示前i个的最大分数,所以dp[i]=max(dp[i-1],dp[j-1]+sum[i]-sum[j-1]) (color i ==color j&&i>j)选与不选的两种决策
但是这样跑为O(N^2),需要优化,发现dp[j-1]-sum[j-1]是个在之前知道的数,所以可以记录下来当需要用这种颜色时的最大dp[j-1]-sum[j-1]
用lst[i]表示在当前情况下需要用color i这种颜色时的最大dp[j-1]-sum[j-1]这个值,因为这两者之间的共处是颜色
所以用颜色维护
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
inline long long read()
{
long long f=,ans=;char c;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){ans=ans*+c-'';c=getchar();}
return f*ans;
}
long long n,k;
long long c[],v[],lst[],sum[],dp[];
int main()
{
memset(lst,-/,sizeof(lst));
n=read(),k=read();
for(long long i=;i<=n;i++) c[i]=read();
for(long long i=;i<=n;i++) v[i]=read(),sum[i]=sum[i-]+v[i];
for(long long i=;i<=n;i++)
{
dp[i]=max(dp[i-],lst[c[i]]+sum[i]);
lst[c[i]]=max(lst[c[i]],dp[i-]-sum[i-]);
}
cout<<dp[n];
}
2.LOJ 2279 降雨量
这道题先要仔细的读题,读完题后发现此题十分可做,但是最后全WA,因为没有看到它的含义是 X 年的降雨量不超过 Y 年这句话
分类讨论+ST表
先用ST表处理(i,j)之间的最大值(i,j为年份下标)
解决问题如果询问i,j
二分寻找u,v年份下标
用nx记录查找的下标对应的值是否等于此年份,因为有可能没有u,v年份的降雨量
然后分类讨论(this is 重点,not ST表)
1)nx==1时
1)ny==1时 已知 x,y(降水量) 那么首先判断x,y的大小,在判断包含区间的关系
2) ny==0时,说明只能与u进行比较,中间包含最大值与x的关系
2)nx==0
1) ny==1时,找中间包含区域与y的关系
2) ny==0,那么两头全部位置,所以maybe
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
inline long long read()
{
long long f=,ans=;char c;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){ans=ans*+c-'';c=getchar();}
return f*ans;
}
long long ma[];
long long n,m;
long long maxn[][];
long long query(long long l,long long r)
{
if(l>r) return -(<<-);
long long k=log2(r-l+);
return max(maxn[l][k],maxn[r-(<<k)+][k]);
}
long long num;
int main()
{
// freopen("rainfall.in","r",stdin);
// freopen("rainfall.out","w",stdout);
// freopen("1.in","r",stdin);
n=read();
for(long long i=;i<=n;i++)
{
ma[i]=read();
maxn[i][]=read();
}
for(long long j=;j<=log2(n);j++)
for(long long i=;i+(<<j)-<=n;i++) maxn[i][j]=max(maxn[i][j-],maxn[i+(<<(j-))][j-]);
m=read();
for(long long i=;i<=m;i++)
{
int ans;
long long x=read(),y=read();
int sx=lower_bound(ma+,ma+n+,x)-ma,sy=lower_bound(ma+,ma+n+,y)-ma;
bool nx=(sx<=n&&ma[sx]==x),ny=(sy<=n&&ma[sy]==y);
// cout<<sx<<" "<<sy<<" "<<nx<<" "<<ny<<endl;
if(nx)
{
if(ny)
{
int q=query(sx+,sy-);
// cout<<q<<" "<<maxn[sx][0]<<" "<<maxn[sy][0]<<endl;
if(maxn[sy][]>maxn[sx][]) ans=;
else if(q<maxn[sy][])
{
if(y-x+==sy-sx+) ans=;
else ans=-;
}
else ans=;
}
else{
int q=query(sx+,sy-);
if(maxn[sx][]>q) ans=-;
else ans=;
}
}
else{
if(ny)
{
int q=query(sx,sy-);
if(q<maxn[sy][]) ans=-;
else ans=;
}else ans=-;
}
if(ans==) printf("true\n");
else if(ans==) printf("false\n");
else printf("maybe\n");
}
}
/*
4
54 8606
77 7706
100 2149
123 900
1
2 54 */
3.LOJ 2332 焚风现象
因为是可以升降海拔高度的但是算的是差值,所以[u,v]区域内答案没有发生影响,至于(u-1,u)与(v,v+1)有影响
每次算值现将二者减去,再分别减,加差值,因为+w所以dis[u-1]+w ,但是对于v来说它是减数所以当他加上一个值时反而是减所以dis[v]-=w
dis[i]表示从i到i+1的海拔高
而因为若v=n时v+1已经越界所以就不再计算
此方法时间复杂度O(q+n)
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
inline long long read()
{
long long f=,ans=;char c;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){ans=ans*+c-'';c=getchar();}
return f*ans;
}
long long n,q,a[],s,t,dis[];
long long get(long long tt)
{
if(tt>) return -s*tt;
return -tt*t;
}
long long ans;
int main()
{
n=read(),q=read(),s=read(),t=read();
for(long long i=;i<=n;i++) a[i]=read();
for(long long i=;i<n;i++)
{
dis[i]=a[i+]-a[i];
ans+=get(dis[i]);
}
while(q--)
{
long long a=read(),b=read(),c=read();
ans-=get(dis[a-]);
dis[a-]+=c;
ans+=get(dis[a-]);
if(b!=n)
{
ans-=get(dis[b]);
dis[b]-=c;
ans+=get(dis[b]);
}
printf("%lld\n",ans);
// cout<<ans<<endl;
}
}
总结:这其实是一场考试,最后100分收尾,只A了第三题,后来发现这是一场普及组的卷子,心态要炸
LOJ 模拟赛的更多相关文章
- 冲刺$\mathfrak{CSP-S}$集训模拟赛总结
开坑.手懒并不想继续一场考试一篇文. 既没必要也没时间侧边栏的最新随笔题解反思相间也丑 而且最近越来越懒了竟然都不写题解了……开坑也是为了督促自己写题解. 并不想长篇大论.简要题解也得写啊QAQ. 目 ...
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- NOI模拟赛 Day1
[考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...
- NOIP第7场模拟赛题解
NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 小奇模拟赛9.13 by hzwer
2015年9月13日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...
- PKUSC 模拟赛 day1 下午总结
下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...
- [GRYZ]寒假模拟赛
写在前面 这是首次广饶一中的OIERS自编自导,自出自做(zuo)的模拟赛. 鉴于水平气压比较低,机(wei)智(suo)的WMY/XYD/HYXZC就上网FQ下海找了不少水(fei)题,经过他们优( ...
随机推荐
- JavaScript基本概念(1)-声明提升
声明提升: function > var > other var提升的时候,只是声明提升,但是赋值还是会在原来的位置. Javascript Hoisting:In javascript, ...
- Python爬虫使用浏览器的cookies:browsercookie
很多用Python的人可能都写过网络爬虫,自动化获取网络数据确实是一件令人愉悦的事情,而Python很好的帮助我们达到这种愉悦.然而,爬虫经常要碰到各种登录.验证的阻挠,让人灰心丧气(网站:天天碰到各 ...
- 【Random】-随机数字-jmeter
参数化 Random 参数化,存储结果的变量名,名字写了,就可以给其它请求使用
- 【转】: 探索Lua5.2内部实现:虚拟机指令(3) Upvalues & Globals
在编译期,如果要访问变量a时,会依照以下的顺序决定变量a的类型: a是当前函数的local变量 a是外层函数的local变量,那么a是当前函数的upvalue a是全局变量 local变量本身就存在于 ...
- Machine Learning笔记整理 ------ (四)线性模型
1. 线性模型 基本形式:给定由d个属性描述的样本 x = (x1; x2; ......; xd),其中,xi是x在第i个属性上的取值,则有: f(x) = w1x1 + w2x2 + ...... ...
- 贵州省未来二十年的投资机会的探讨1>
贵州的股市 1.000540.SZ 中天金融 2.000589.SZ 黔轮胎A 3.000733.SZ 振华科技 4.000851.SZ 高鸿股份 5.000920.SZ 南方汇通 6.002025. ...
- 1.linux环境配置
首先说一下,这里是虚拟机环境. 1.用vbox安装centos6.8-mini 注意不要使用复制的方式安装,复制的虚拟机网络不通 安装如下: 主机 ip 角色 内存 hadoop1 192.168.0 ...
- Centos6配置开启FTP Server
vsftpd作为FTP服务器,在Linux系统中是非常常用的.下面我们介绍如何在centos系统上安装vsftp. 什么是vsftpd vsftpd是一款在Linux发行版中最受推崇的FTP服务器程序 ...
- Samba共享权限分配
案例推荐:http://www.cnblogs.com/mchina/archive/2012/12/18/2816717.html 本文不详细介绍全部参数,只介绍完成需求的一些参数. 需求: 1,账 ...
- "Hello world!"团队第一次会议
今天是我们"Hello world!"团队第一次召开会议,今天的会议可能没有那么正式,但是我们一起确立了选题——基于WEB的售票系统.博客内容是: 1.会议时间 2.会议成员 3. ...