poj2228 分第一天是否熟睡DP两次

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std; int n,B,ans,a[],f[][][];
void DP1()
{
int now=;
memset(f[now],-,sizeof(f[now]));
f[now][][]=f[now][][]=;
for(int i=;i<=n;i++)
{
now^=;
memset(f[now],-,sizeof(f[now]));
f[now][][]=;
for(int j=;j<=min(i,B);j++)
{
f[now][j][]=max(f[now^][j][],f[now^][j][]);
f[now][j][]=max(f[now^][j-][],f[now^][j-][]+a[i]);
}
}
ans=max(ans,max(f[now][B][],f[now][B][]));
}
void DP2()
{
int now=;
memset(f[now],-,sizeof(f[now]));
f[now][][]=a[];
for(int i=;i<=n;i++)
{
now^=;
memset(f[now],-,sizeof(f[now]));
for(int j=;j<=min(i,B);j++)
{
f[now][j][]=max(f[now^][j][],f[now^][j][]);
if(j!=)f[now][j][]=max(f[now^][j-][],f[now^][j-][]+a[i]);
}
}
ans=max(ans,f[now][B][]);
} int main()
{
scanf("%d%d",&n,&B);
for(int i=;i<=n;i++)scanf("%d",&a[i]);
ans=;DP1();DP2();
printf("%d\n",ans);
return ;
}

poj2228

环形运输 复制接后头,明显有单调性

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std; int a[],q[];
int main()
{
int n;
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d",&a[i]);
if(i!=n)a[i+n]=a[i];
} int head=,tail=,mmax=;q[]=;
for(int i=;i<=*n-;i++)
{
while(head<tail&&i-q[head]>n/)head++;
mmax=max(mmax,a[i]+a[q[head]]+i-q[head]);
while(head<=tail&&a[i]>=a[q[tail]]+i-q[tail])tail--;
q[++tail]=i;
}
printf("%d\n",mmax);
return ;
}

环形运输

cf 24D 这是有后效性的题,解个方程咯,这里是两个二元其他三元那就左往右一个个消,实在元素多就gauss咯

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std; double a[],b[],f[][];
int main()
{
int n,m,stx,sty;
scanf("%d%d%d%d",&n,&m,&stx,&sty);
if(m==)
{
a[n]=;for(int i=n-;i>=stx;i--)a[i]=a[i+]+;
printf("%.4lf\n",a[stx]);
return ;
}
for(int i=;i<=m;i++)f[n][i]=;
for(int i=n-;i>=stx;i--)
{
a[]=1.0/2.0;
b[]=(f[i+][]+3.0)/2.0;
for(int j=;j<m;j++)
{
a[j]=1.0/(3.0-a[j-]);
b[j]=(f[i+][j]+b[j-]+4.0)/(3.0-a[j-]);
}
f[i][m]=(b[m-]+f[i+][m]+3.0)/(2.0-a[m-]);
for(int j=m-;j>=;j--)f[i][j]=a[j]*f[i][j+]+b[j];
}
printf("%.4lf\n",f[stx][sty]);
return ;
}

cf 24D

0x55 环形与后效性问题的更多相关文章

  1. poj 2228 Naptime(DP的后效性处理)

    \(Naptime\) \(solution:\) 这道题不做多讲,它和很多区间DP的套路一致,但是这一道题它不允许断环成链,会超时.但是我们发现如果这只奶牛跨夜休息那么它在不跨夜的二十四个小时里一定 ...

  2. luogu 4042 有后效性的dp

    存在有后效性的dp,但转移方程 f[i] = min( f[i], s[i] + sigma f[j] ( j 是后效点) ) 每次建当前点和 转移点的边 e1, 某点和其会影响的点 e2 spfa ...

  3. Educational Codeforces Round 62 E 局部dp + 定义状态取消后效性

    https://codeforces.com/contest/1140/problem/E 局部dp + 定义状态取消后效性 题意 给你一个某些位置可以改变的字符串,假如字符串存在回文子串,那么这个字 ...

  4. Codeforces - 24D 有后效性的DP处理

    题意:在n*m的网格中,某个物体初始置于点(x,y),每一步行动都会等概率地停留在原地/往左/往右/往下走,求走到最后一行的的步数的数学期望,其中n,m<1000 lyd告诉我们这种题目要倒推处 ...

  5. Luogu P2973 [USACO10HOL]赶小猪Driving Out the Piggi 后效性DP

    有后效性的DP:$f[u]$表示到$u$的期望次数,$f[u]=\Sigma_{(u,v)} (1-\frac{p}{q})*f[v]*deg[v]$,最后答案就是$f[u]*p/q$ 刚开始$f[1 ...

  6. CF24D Broken robot 后效性DP

    这题咕了好久..... 设$f[i][j]$表示从$(i,j)$到最后一行的期望步数: 则有 $ f[i][1]=\frac{1}{3}(f[i][1]+f[i][2]+f[i+1][1])+1$ $ ...

  7. caioj 1084 动态规划入门(非常规DP8:任务安排)(取消后效性)

    这道题的难点在于,前面分组的时间会影响到后面的结果 也就是有后效性,这样是不能用dp的 所以我们要想办法取消后效性 那么,我们就可以把影响加上去,也就是当前这一组加上了s 那么就把s对后面的影响全部加 ...

  8. Cogs 376. [IOI2002]任务安排(后效性DP)

    [IOI2002]任务安排 ★☆ 输入文件:batch.in 输出文件:batch.out 简单对比 时间限制:1 s 内存限制:128 MB N个任务排成一个序列在一台机器上等待完成(顺序不得改变) ...

  9. BZOJ3875--骑士游戏(SPFA处理带后效性的动态规划)

    3875: [Ahoi2014]骑士游戏 Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 181  Solved: 91[Submit][Status] ...

随机推荐

  1. SQL Server跨库跨服务器访问实现

    我们经常会遇到一个数据库要访问另一个数据库,或者一台服务器要访问另一台服务器里面的数据库. 那么这个如何实现的呢? 相信看完这篇文章你就懂了! 同一台服务器跨库访问实现 1. 首先创建两个数据库Cro ...

  2. MainActivity 多个Fragment 内存被回收

    0. 前言 应用首页采用Activity +Tab 模式,多个Fragment 替换显示隐藏 FragmentTransaction transaction = getSupportFragmentM ...

  3. ie8及其以下版本兼容性问题之input file隐藏上传文件

    文件上传时,默认的file标签很难看,而且每个浏览器下都有很大差距.因此我们基本都把真正的file标签给隐藏,然后创建一个标签来替代它.但是由于IE出于安全方面的考虑上传文件时必须点击file的浏览按 ...

  4. [ller必读] LoveLive! 必备技能之 Python Pillow 自动处理截图

    起因 喜欢的歌,静静地听:喜欢的人,远远的看.30天前,就是3月14号,我情不自禁地走近了<LoveLive!学院偶像祭>,这是我的第一张卡片(见下图).第二天也就是3月15日,海未生日了 ...

  5. HDU_1398_母函数

    Square Coins Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tota ...

  6. kafka概述与下一代消息队列

    常用的消息中间件 消息中间件是当前处理大数据的一个非常重要的组件,用来解决应用解耦.异步通信.流量控制等问题,从而构建一个高效.灵活.消息同步和异步传输处理.存储转发.可伸缩和最终一致性的稳定系统.目 ...

  7. 国庆day2

    a[问题描述]你是能看到第一题的 friends呢.—— hja世界上没有什么比卖的这 贵弹丸三还令人绝望事了,所以便么一道题.定义

  8. 字符串函数(day11)

    使用存储区的地址作为返回值可以让调用 函数使用被调用函数的存储区 这种时候被调用函数需要提供一个指针类型 的存储区记录作为返回值的地址数据 不可以把非静态局部变量的地址作为返回值 使用 C语言里的文字 ...

  9. Linux思维导图之查找命令

    常用查找命令的区别:

  10. 使用VirtualBox实现端口转发,以SSH与Django为例

    先来认识几个概念 (1)IP地址:又称为互联网协议地址,是计算机的物理地址,相当于计算机的编号,是32位的二进制数,通常被分割成4个8位的二进制数: (2)端口:指设备与外界通讯的接口,一台计算机的端 ...