A
standard input/output

1 s, 256 MB

   x1916
B
standard input/output

1 s, 256 MB

   x3290
C
standard input/output

1 s, 256 MB

   x527
D
standard input/output

1 s, 256 MB

   x191
E
standard input/output

1 s, 256 MB

   x10

-----------

A 934A

两个人T,B有n和m个灯笼,

要从每个人选出一个灯笼,放在一起,其权值为两者之积,注意权值可以为负数

B来选择两个灯笼组合,目的是组合结果最大

T要提前删去一个灯笼,目的是让组合结果最小,注意T是知道两人的灯笼情况的

求最后B的最大值

分析:

模拟,算出所有组合,找到最大组合中T的灯笼编号A,然后删掉所有包含A的灯笼组合

注意:需要开ll,删除的时候可以用vis数组,可以用-INF,可以用最小的灯笼组合-INF

推荐vis数组和最小组合-INF,如果用-INF必须足够小,建议-2e18或者-0x3f3f3f3f3f3f3f3f

----------

B 934B

题意:

给一个n,要求输出一个数字,阿拉伯数字中封闭区域的数量等于n,不存在输出-1;,要求答案小于等于18位

分析

题目说的很不清楚,任何组合都是存在的,只是很多无法在19位之前达到而已,具体应该是"能在18位之内达到就输出,否则输出-1"

首先8是2个,6,4,9,0,是一个,

然后注意0不能做前导数字,所以不用0,在4,6,9里任选就行

一开始如果大于36(18个8)就输出-1

然后贪心就行...

---------

C 934C

题意:

给一个1,2组成的数列,可以将一个区间翻转,求最大的不下降子序列

分析:

比赛时候最后几分钟有了思路,那一瞬间脑内进行了大概1e5次博弈,然后决定放弃...

复杂度n2,qls说其实是线性的算法,orz..

首先 答案的子序列一定是111111....11222....2这样,注意有可能没有1或者没有2

递推过程,为了进行决策,先分析一波:

  1.如果当前是以2结尾的未翻转子序列最长,后面的区间根本不需要翻转.对结果没有影响

  2.如果当前是以1结尾的未翻转子序列最长,对于后面的所有翻转选择,

     以1开头的子区间一定不是最优的,简单来说 要反转肯定是从2开始,

     而如果要反转,最终的子序列一定是以2结尾,而且第一个2是在反转的区间之内,不然反转毫无意义

所以最终的决策就是:

 1.不反转,这部分的最大值可以提前On预处理得到,用递推或者前缀和都可以得到

  可以dp[x][maxn] 分别保存1结尾,2结尾+反转,也可以用一个值保存1结尾/2结尾不反转的最大值

 2,反转 我们考虑子序列的3个部分,反转区间之前,反转区间,反转区间之后

    反转区间之前,肯定是1结尾,所以直接由预处理的前缀和得到

    反转区间之后,肯定是2开头2结尾,所以也是预处理前缀和得到

    反转区间中,一定是1.....12....2这样,没有别的情况了

  那具体怎么实现?

  具体过程就是直接枚举反转区间里面,第一个2的位置

  然后分别向前和向后枚举反转区间的起点p1和终点p2

  转移的时候,利用前缀和计算,转移时间是O(1)

  记第一个2的位置为P0,显然翻转之后,P0左边的2全部到P0右边了,右边的1到了左边

  所以,P0左边的最长子序列是S1[1,p1-1]+S2[p1,p0],p0右边是S2[p2+1,n]+S1[p0,p2]

  然后比较 1结尾不反转的最大值,以2结尾且反转的最大值(区间长度为1的时候就是不反转)

  简单来说还是...On2的算法...

 /**********************
*@Name:
*
*@Author: Nervending
*@Describtion:
*@DateTime:
***********************/
#include <bits/stdc++.h>
#define show(x) cout<<#x<<"="<<x<<endl
using namespace std;
const int maxn=1e5+;
const int maxm=1e6+;
const int INF=0x3f3f3f3f;
typedef long long ll;
typedef unsigned long long ull;
int casn,n,m,k;
int num[maxn];
int s1[maxn],s2[maxn];
int dp[][maxn];
int ans;
int main() {
//#define test
#ifdef test
freopen("in.txt","r",stdin);
freopen("out.txt","w",stdout);
#endif cin>>n;
for(int i=; i<=n; i++) {
cin>>num[i];
s1[i]=s1[i-]+(num[i]==);
s2[i]=s2[i-]+(num[i]==);
}
for(int i=; i<=n; i++) {
if(num[i]==) dp[][i]=max(dp[][i-],dp[][i-])+;
else {
dp[][i]=dp[][i-]+;
dp[][i]=dp[][i-];
}
}
for(int i=; i<=n; i++) {
ans=max(dp[][i],max(ans,dp[][i]));
if(num[i]!=) continue;
for(int j=; j<=i; j++) {
dp[][i]=max(dp[][i],s1[j-]+(s2[i]-s2[j-]));
}
for(int j=i; j<=n; j++) {
dp[][i]=max(dp[][i],s1[j]-s1[i]+(s2[n]-s2[j]));
}
ans=max(ans,dp[][i]+dp[][i]);
}
cout<<ans<<endl; #ifdef test
fclose(stdin);
fclose(stdout);
system("out.txt");
#endif
return ;
}

codeforces 462div.2的更多相关文章

  1. python爬虫学习(5) —— 扒一下codeforces题面

    上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...

  2. 【Codeforces 738D】Sea Battle(贪心)

    http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...

  3. 【Codeforces 738C】Road to Cinema

    http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...

  4. 【Codeforces 738A】Interview with Oleg

    http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...

  5. CodeForces - 662A Gambling Nim

    http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...

  6. CodeForces - 274B Zero Tree

    http://codeforces.com/problemset/problem/274/B 题目大意: 给定你一颗树,每个点上有权值. 现在你每次取出这颗树的一颗子树(即点集和边集均是原图的子集的连 ...

  7. CodeForces - 261B Maxim and Restaurant

    http://codeforces.com/problemset/problem/261/B 题目大意:给定n个数a1-an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a ...

  8. CodeForces - 696B Puzzles

    http://codeforces.com/problemset/problem/696/B 题目大意: 这是一颗有n个点的树,你从根开始游走,每当你第一次到达一个点时,把这个点的权记为(你已经到过不 ...

  9. CodeForces - 148D Bag of mice

    http://codeforces.com/problemset/problem/148/D 题目大意: 原来袋子里有w只白鼠和b只黑鼠 龙和王妃轮流从袋子里抓老鼠.谁先抓到白色老鼠谁就赢. 王妃每次 ...

随机推荐

  1. Web API中给领域模型添加媒体类型支持

    一.媒体类型 媒体类型(也称为MIME类型)标识一段数据的格式.在HTTP中,媒体类型描述了消息体的格式.媒体类型由两个字符串组成,一个类型和一个子类型.例如:text / html: image/ ...

  2. windows配置Java环境变量

    打开电脑的高级系统设置-高级-环境变量 新建系统变量,如果已存在则添加到变量尾部,切勿覆盖 变量名:JAVA_HOME 变量值:C:\Program Files\Java\jdk1..0_102 变量 ...

  3. 062、如何使用flannel host-gw backend(2019-04-02 周二)

    参考https://www.cnblogs.com/CloudMan6/p/7457653.html   flannel 支持多种backend,前面学习的是 vxlan backend ,host- ...

  4. docker 系列 - 企业级私有镜像仓库Harbor部署(转载)

     本文转载自 搜云库 的文章 https://www.jianshu.com/p/7d76850de03f  , 感谢作者 3.png 上一篇文章搭建了一个具有基础功能,权限认证.TLS 的私有仓库, ...

  5. 子线程导致 Windows 服务停止的情况(Topshelf 结合 Quartz.NET)

    Ø  前言 本文主要记录子线程导致 Topshelf 和 Quartz.NET 的 Windows 服务停止的现象,以及使用几种常用子线程的注意事项.因为我们有时可能需要开启多个线程执行复杂的逻辑,如 ...

  6. man termios(FreeBSD 12.0)

    TERMIOS() FreeBSD Kernel Interfaces Manual TERMIOS() NAME termios - general terminal line discipline ...

  7. error: Microsoft Visual C++ 14.0 is required. Get it with "Microsoft Visual C++ Build Tools": http://landinghub.visualstudio.com/visual-cpp-build-tools

    解决方案 1. http://www.lfd.uci.edu/~gohlke/pythonlibs/#twisted 下载twisted对应版本的whl文件(我的Twisted‑17.5.0‑cp36 ...

  8. 求f(n)=[n/1]+[n/2]+---+[n/n]的值 简单杂题

    这种小题首先根据 n/1+n/2+n/3+--+n/n=nlogn+欧拉常数r 可以知道 1e12的范围也不会爆longlong,不需要写高精度(到现在都不会写) 再根据数据范围可知O(n)级别的暴力 ...

  9. [C++]PAT乙级1009. 说反话 (17/20)

    /* 1009. 说反话 (20) 给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出. 输入格式: 测试输入包含一个测试用例, 在一行内给出总长度不超过80的字符串. 字符串由若干单词和若干 ...

  10. [C++]Linux之虚拟文件系统[/proc]中关于CPU/内存/网络/内核等的一些概要性说明

    声明:如需引用或者摘抄本博文源码或者其文章的,请在显著处注明,来源于本博文/作者,以示尊重劳动成果,助力开源精神.也欢迎大家一起探讨,交流,以共同进步- 0.0 1.Linux虚拟文件系统 首先要明白 ...