cf C. Fragile Bridges
来源:互联网 发布:linux设备驱动程序pdf 编辑:程序博客网 时间:2024/05/17 00:18
这道题看了题解,认识了多方向的dp,但是我明白的还是太少了,至于在求最大值的时候算的是o(n*n),TLE了,虽然方法正确,但是还是没有真正的了解思路。。。。
dr[i]表示的是从i点出发向右走再回到i点时的最大路程,同理dl[i]
sumr[i]表示的是从i点出发i~n点间的最大路程,同理suml[i],(开始时设错了,以为是从0出发到i点的最大路程,这样的话在后面求最大值的时候就要sum[i]-sum[j]+dr[i]+dl[i],这样也不用求两个sum了,但是这样会TLE,其实现在还是有点乱的~~)
这样,
在求最大值时就枚举一遍n就行了,时间复杂度为O(N),
maxn=max(maxn,max(suml[i]+dr[i],sumr[i]+dl[i])),
这种思想现在还是不太想得通,需要多做练习,但是现在都快大三了,这不知道我这样坚持下去对不对?因为自己的基础太差了。。。
别人判断奇偶的时候用的是a&1,其实就是与,真为奇,或者a&0x1(0x为16进制)
题解1
题解2
#include <iostream>#include <cstdio>#include <cstring>#include <algorithm>using namespace std;#define N 100010typedef long long LL;LL dl[N],dr[N],suml[N],sumr[N],a[N];int n;int main(){ scanf("%d",&n); for(int i=1;i<n;i++) scanf("%I64d",&a[i]); dl[1]=0;dr[n]=0;suml[1]=0,sumr[n]=0; for(int i=2;i<=n;i++) { dl[i]=a[i-1]==1?0:(dl[i-1]+a[i-1]/2*2); suml[i]=max(dl[i],suml[i-1]+1+(a[i-1]-1)/2*2); } /*for(int i=1;i<=n;i++) cout<<dl[i]<<" "; cout<<endl; for(int i=1;i<=n;i++) cout<<suml[i]<<" "; cout<<endl;*/ for(int i=n-1;i>=1;i--) { dr[i]=a[i]==1?0:(dr[i+1]+a[i]/2*2); sumr[i]=max(dr[i],sumr[i+1]+(a[i]-1)/2*2+1); } /*for(int i=1;i<=n;i++) cout<<dr[i]<<" "; cout<<endl; for(int i=1;i<=n;i++) cout<<sumr[i]<<" "; cout<<endl;*/ LL maxn=0; for(int i=1;i<=n;i++) { maxn=max(maxn,max(suml[i]+dr[i],sumr[i]+dl[i])); } printf("%I64d\n",maxn); return 0;}
0 0
- cf C. Fragile Bridges
- codeforces 201C Fragile Bridges
- cf 127 div .1 Fragile Bridges(dp 好题)
- Codeforces Round #127 (Div. 1) C. Fragile Bridges
- Codeforces Round #127 (Div. 1) C. Fragile Bridges
- Codeforces Round #127 (Div. 1), problem: (C) Fragile Bridges 优先队列
- Codeforces Round #127 (Div. 2) C - Fragile BridgesCodeforces
- Life is fragile
- Non Fragile ivars
- CF 190C STL
- CF 79C. Beaver
- CF 229C Triangles
- CF 4 C
- cf 230c
- CF 255C
- CF 27C
- CF 52C
- CF 190C
- ContentProvider再探——Document Provider
- 关于同一域名下的不同的二级域名可以共享cookie在thinkphp里的解决办法
- PHP_mysql_连接数据库+读取数据
- 检查异常和未检查异常不同之处
- 一张图了解物联网知识点
- cf C. Fragile Bridges
- 一个远程数据采集系统的实现
- Question_one_数据库插入数据无法显示中文
- 最小路径覆盖 poj1422 Air Raid
- [2031]:进制转换
- Java中对数组的排序方法总汇分析
- Java 注解(一)
- java内存
- elasticsearch-2集群搭建的坑