布谷。

欢迎大家来不耻下问。

这里是正解不会,暴力写跪,乱搞鸡肋的某虻 。


好想放假啊!!!!

话说猫厂现在产量低迷……

ZJ一下:

T1,三维偏序,只码了$\Theta(N^2)$暴力

T2,暴力愉快。

T3,输〇片分。

简单TJ:

T1

因为这个题的要求比较特殊,求解的答案可以和一个输入的顺序一起维护。

首先通过排序将$A$数组的偏序限制解决

然后用树状数组暴干$B$数组的大小,将位置插入树状数组比较维护。

最后的答案直接查即可。

#include <algorithm>
#include <iostream>
#include <cstring>
#include <climits>
#include <vector>
#include <cstdio>
#define N 555555
#define LL long long using namespace std; const int lim=500000;
LL pn;
struct PRE{
LL id,pa,pb;
}ps[N];
vector<LL>vls;
LL pre[N];
LL ans=0; inline LL fvind(LL a){
return lower_bound(vls.begin(),vls.end(),a)-vls.begin()+1;
}
inline LL lowbit(int x){
return x&(-x);
}
void add(LL pos,LL val){
while(pos<=lim){
pre[pos]=min(pre[pos],val);
pos+=lowbit(pos);
}
}
LL query(LL pos){
LL res=LLONG_MAX;
while(pos){
res=min(res,pre[pos]);
pos-=lowbit(pos);
}
return res;
}
int main(){
LL a;
ios_base::sync_with_stdio(false);
cin>>pn;
for(int i=1;i<=pn;i++)ps[i].id=i;
for(int i=1;i<=pn;i++){
cin>>a;
ps[i].pa=ps[i-1].pa+a;
}
vls.push_back(0);
for(int i=1;i<=pn;i++){
cin>>a;
ps[i].pb=ps[i-1].pb+a;
vls.push_back(ps[i].pb);
}
// for(auto i:vls){\
cout<<i<<" ";\
}cout<<endl;
sort(vls.begin(),vls.end());
vls.erase(unique(vls.begin(),vls.end()),vls.end());
// for(auto i:vls){\
cout<<i<<" ";\
}cout<<endl;
for(int i=0;i<=pn;i++){
ps[i].pb=fvind(ps[i].pb);
}
sort(ps,ps+pn+1,[](const PRE &a,const PRE &b)
{return a.pa==b.pa?a.id<b.id:a.pa<b.pa;});
// for(int i=1;i<=pn;i++){\
cout<<ps[i].pa<<" "<<ps[i].pb<<" "<<ps[i].id<<endl;\
}
memset(pre,0x7f,sizeof pre);
// add(ps[0].pb,0);
for(int i=0;i<=pn;i++){
LL vl=query(ps[i].pb);//cout<<ps[i].id<<"val:"<<vl<<endl;
add(ps[i].pb,ps[i].id);
ans=max(ans,ps[i].id-vl);
}
cout<<ans<<endl;
}

T2

证明先咕下。

利用决策单调性,将$\Theta(N^3)$优化成$\Theta(N^2)$

#include <iostream>
#include <climits>
#include <cstring>
#include <cstdio>
#define N 5555
#define LL long long using namespace std; int pn;
LL arr[N],pre[N],
dp[N][N],
ap[N][N]; int main(){
cin.sync_with_stdio(false);
cin>>pn;
for(int i=1;i<=pn;i++){
cin>>arr[i];
pre[i]=pre[i-1]+arr[i];
}
for(int i=1;i<=pn;i++){
for(int j=1;j<=pn;j++){
if(i<=j)dp[i][j]=LLONG_MAX/3;
else dp[i][j]=0;
}
}
for(int i=1;i<=pn;i++){
dp[i][i]=arr[i];
ap[i][i]=i;
}
for(int i=1;i<pn;i++){
for(int j=1;j+i<=pn;j++){
int l=j,r=j+i;
// cout<<l<<" "<<r<<endl;
// cout<<ap[l][r-1]<<"~"<<ap[l+1][r]<<endl;
for(int k=ap[l][r-1];k<=ap[l+1][r];k++){
// cout<<dp[l][r]<<" <<<< "<<dp[l][k-1]<<"+"<<dp[k+1][r]<<endl;
if(dp[l][r]>dp[l][k-1]+dp[k+1][r]){
dp[l][r]=dp[l][k-1]+dp[k+1][r];
ap[l][r]=k;
}
}
dp[l][r]+=pre[r]-pre[l-1];
}
}
cout<<dp[1][pn]<<endl;
}

T3

大神题,好像和一些神奇的高斯消元有关。

19-10-29-Night-X的更多相关文章

  1. 背水一战 Windows 10 (29) - 控件(文本类): RichTextBlock, RichTextBlockOverflow, RichEditBox

    [源码下载] 背水一战 Windows 10 (29) - 控件(文本类): RichTextBlock, RichTextBlockOverflow, RichEditBox 作者:webabcd ...

  2. SpringBoot+mybatis:报错Fri Oct 19 14:29:24 CST 2018 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requiremen

    报错:Fri Oct 19 14:29:24 CST 2018 WARN: Establishing SSL connection without server's identity verifica ...

  3. 【Selenium】【BugList9】windows环境,fp = open("./"+ time.strftime("%Y-%m-%d %H:%M:%S") + " result.html",'wb'),报错:OSError: [Errno 22] Invalid argument: './2018-09-05 10:29:32 result.html'

    [代码] if __name__=="__main__": suite = unittest.TestSuite() suite.addTest(Baidu("test_ ...

  4. 10.29 正睿停课训练 Day11

    目录 2018.10.29 正睿停课训练 Day11 A 线段树什么的最讨厌了(思路 DFS) B 已经没有什么好害怕的了(差分 前缀和) C 我才不是萝莉控呢(DP 贪心 哈夫曼树) 考试代码 A ...

  5. 第17次Scrum会议(10/29)【欢迎来怼】

    一.小组信息 队名:欢迎来怼小组成员队长:田继平成员:李圆圆,葛美义,王伟东,姜珊,邵朔,冉华 小组照片 二.开会信息 时间:2017/10/29 17:20~17:42,总计22min.地点:东北师 ...

  6. Ubuntu 19.10 发布 | 云原生生态周报 Vol. 24

    作者 | 木苏.进超.冬岛.元毅.心水.衷源 业界要闻 1.云原生编程语言 Pulumi 1.0 pulumi ,一款中立的开源云开发平台,Pulumi 支持多语言.混合云环境.完全可扩展.初期支持 ...

  7. [Linux] 在 Ubuntu 19.10 上开启 SSH 服务并允许远程登录

    在 Ubuntu 19.10 上安装 SSH,并开启服务 0.检查并确认系统当前是否已安装SSH: sudo ps -e | grep ssh 如果只有 ssh-agent 说明 ssh-server ...

  8. [Linux] 树莓派 4B 安装 Ubuntu 19.10 (Eoan Ermine) IOT 版

    硬件:Raspberry Pi 4B系统:Ubuntu 19.10 (Eoan Ermine) for IOT官网:https://ubuntu.com/download/iot/raspberry- ...

  9. 2016.10.29初中部上午NOIP普及组比赛总结

    2016.10.29[初中部 NOIP普及组 ]模拟赛 做得好爽! 进度: 比赛:35+45+AC+0=180 改题:AC+AC+AC+0=300 幸运的数 有点无语--之前怕超限,还特意利用程序打了 ...

  10. Ubuntu 19.10 安装 jupyter

    安装pip3 ubuntu 19.10 已经没有python了,取代的是python3. 执行sudo apt install python3-pip安装pip3 安装jupyter 执行sudo p ...

随机推荐

  1. Linux上 安装Sorl4.7 中间件用tomcat

    最近需要用到solr,公司内部搭建了一个solr测试环境. 版本:solr4.7.2 ,tomcat 7.0.55 jdk:1.7_051 解压 solr 和tomcat  这里就不详说. 1.启动t ...

  2. 线性可分SVM中线性规划问题的化简

    在网上找了许多关于线性可分SVM化简的过程,但似乎都不是很详细,所以凭借自己的理解去详解了一下. 线性可分SVM的目标是求得一个超平面(其实就是求w和b),在其在对目标样本的划分正确的基础上,使得到该 ...

  3. Django开发学习BUG记录--RemovedInDjango19Warning:Model class apps.user.models.User doesn't declare an explicit app_label

    报错信息: /home/python/PycharmProjects/dailyfresh/apps/user/models.py:8: RemovedInDjango19Warning: Model ...

  4. css布局-瀑布流的实现

    一.基本思路 1.先看最终的效果图: 2.实现原理:通过position:absolute(绝对定位)来定位每一个元素的位置,并且将当前列的高度记录下来方便下一个dom位置的计算 二.代码实现 1.版 ...

  5. Activiti学习笔记1 — 下载与开发环境的配置

    一.下载 JDK下载URL: Tomcat下载URL:http://tomcat.apache.org/ Eclipse下载URL:http://www.oracle.com/technetwork/ ...

  6. 判断APP是否已安装

    NSString *str = [NSString stringWithFormat:@"%@://%@",[dic objectForKey:@"ios_url_sch ...

  7. Android开发 MediaPlayer播放raw资源MP3文件

    代码 private MediaPlayer mRingPlayer; /** * 播放铃声 */ private void startRing(){ if (mRingPlayer != null) ...

  8. Android studio 添加引用Module项目 与 设置Module项目的Libs的Jar在主项目里使用

    前言 添加引用Module项目 设置Module项目的Libs的Jar在主项目里使用 1.在项目里添加libs包,并且加入jar 2.设置这个module项目的build.gradle depende ...

  9. 【JZOJ5433】图

    description 有一个n个点A+B条边的无向连通图,有一变量x,每条边的权值都是一个关于x的简单多项式,其中有A条边的权值是k+x,另外B条边的权值是k-x,如果只保留权值形如k+x的边,那么 ...

  10. jvm虚拟内存分布 与 GC算法

    jvm虚拟内存分布 程序计数器(PC寄存器)(线程私有): 每个线程启动的时候,都会创建一个PC(Program Counter,程序计数器)寄存器. PC寄存器的内容总是指向下一条将被执行指令的地址 ...