题意:给你一个有向图,一共N个顶点,且每个顶点只有一个前驱或后继,在顶点上建立圣地,那么就可以获得一个信仰值,如果在这个顶点的后继节点上也建立圣地,那么将改变一定的信仰值,求解能获取的最大信仰值。



思路:好吧,这题一点思路都没有,本来题目就做的比别人少,树状DP什么的,更是少,这次要不是准备好好研究下DP问题,估计想都没想过去接触这种东西,只怪自己太懒了。题目是求最大值的,所以考虑要不要在这个点上新建圣地问题,那么就分两种情况了,所以取其中最大的值就行,由于题目给的是简单环,所以之前要进行处理下,n个顶点,n条边,所有先处理环上的树枝节点,然后再对环做DP就可以。

#include<stdio.h>
#include<string.h>
#include<iostream>
using namespace std;
typedef long long LL;
const int MAX=100010; LL in_degree[MAX],sec[MAX],g[MAX],f[MAX],q[MAX];
LL DP[MAX][2],re[MAX][2];
bool flag[MAX];
LL n,k;
LL sum;
int i,j; LL ss(LL f,LL now,LL DP[][2],LL flag)
{
LL i,j,k;
k=now;
i=sec[k];
while(i!=f)
{
DP[i][0]+=max(DP[k][0],DP[k][1]);
DP[i][1]+=max(DP[k][0],DP[k][1]+g[k]);
k=sec[k];
i=sec[k];
}
if(flag) DP[k][1]+=g[k];
return max(DP[k][0],DP[k][1]);
}
LL solve(LL now)
{
LL i,j,xx,k;
k=now;
i=sec[k];
re[i][0]+=DP[k][0];
re[i][1]+=DP[k][0];
j=ss(now,i,re,0); DP[i][0]+=DP[k][1];
DP[i][1]+=DP[k][1]+g[k];
xx=ss(now,i,DP,1);
return max(j,xx);
}
void branch()
{
int x;
for(x=0,i=1; i<=n; i++)
{
DP[i][1]=f[i];
if(!in_degree[i])
q[x++]=i;
}
while(x)
{
k=q[--x]; flag[k]=true;
i=sec[k]; DP[i][0]+=max(DP[k][0],DP[k][1]);
DP[i][1]+=max(DP[k][0],DP[k][1]+g[k]); if(--in_degree[i]==0LL)
q[x++]=i;
}
}
LL ring()
{
memcpy(re,DP,sizeof(DP)); for(sum=0,i=1; i<=n; i++)
{
if(!flag[i])
{
sum+=solve(i);
flag[i]=true;
for(j=sec[i]; j!=i; j=sec[j])
flag[j]=true;
}
}
return sum;
} int main()
{
while(scanf("%lld",&n)!=EOF)
{
memset(in_degree,0,sizeof(in_degree));
memset(DP,0,sizeof(DP));
memset(flag,false,sizeof(flag)); for(i=1; i<=n; i++)
{
scanf("%lld%lld%lld",&f[i],&g[i],&sec[i]);
in_degree[sec[i]]++;
} branch(); //将树枝节点分离并且计算
printf("%lld\n",ring()); //另外对环上的所有点DP
}
return 0;
}

ZOJ3527的更多相关文章

随机推荐

  1. 传值 UI考试知识点

    传值: 1. 属性传值:从前往后 2. 代理传值:从后往前 3. block: 4. 单例:普通写法和GCD写法 5 . 通知 NSNotification GCD 单例: static PlayMu ...

  2. vs2013update4 vs-mda-remote cordova真机测试ios 解决里面一个坑

    sudo npm install -g vs-mda-remote --user=你的用户名 此步骤为安装vs-mda-remote,如果安装成功 执行vs-mda-remote –secure fa ...

  3. 如何完美打造Win8 Metro版IE10浏览器页面(转)

    Windows8 内置两种 Internet Explorer 10 (以下简称 IE10),一个是在桌面环境下使用的 IE10:视窗操作.可以支持各种插件(ActiveX):而另外一个则是在新的开始 ...

  4. C#中&与&&的区别

    刚刚翻书发现这个问题,在网上找了一下,我的理解吧. 他俩的区别就是“&”和“|”不执行短路计算,而&&和||执行了短路计算. &不执行短路计算 ——————表达式A&a ...

  5. mysql oracle 删除外键约束

    mysql alter table xxx drop foreign key xxx cascade; oracle alter table drop constraint xxxxx cascade ...

  6. BZOJ 1027 合金

    Description 某公司加工一种由铁.铝.锡组成的合金.他们的工作很简单.首先进口一些铁铝锡合金原材料,不同种类的原材料中铁铝锡的比重不同.然后,将每种原材料取出一定量,经过融解.混合,得到新的 ...

  7. 使用Flexible 实现手淘H5 页面的终端适配学习

    Amfe阿里无线前端团队双11技术连载之际,一个实战案例来展示多终端适配. Device metrics 1.0 mdpi 2.0 xhdpi 3.0xxhdpi(iphone 6 plus) 手淘h ...

  8. SpringMvc配置 导致实事务失效

    SpringMVC回归MVC本质,简简单单的Restful式函数,没有任何基类之后,应该是传统Request-Response框架中最好用的了. Tips 1.事务失效的惨案 Spring MVC最打 ...

  9. 分页SQL模板

    select * from ( select rownum as rn ,a.* from ( select * from page a where object_id >1000 and ow ...

  10. Socket(TCP)客户端请求和服务端监听和链接基础(附例子)

    一:基础知识回顾 一: Socket 类 实现 Berkeley 套接字接口. Socket(AddressFamily, SocketType,ProtocolType) 使用指定的地址族.套接字类 ...