选课 树形dp+路径输出
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 2010
using namespace std;
int n,m,v[maxn],sum[maxn],son[maxn][maxn],s[maxn][],f[maxn][maxn];
bool falg[maxn];
int Dfs(int k,int p)
{
if(k==&&p!=m||p==)return ;
if(f[k][p])return f[k][p];
int s1=,s2=,lc=son[k][],rc=son[k][];
if(rc)s1=Dfs(rc,p);
for(int i=;i<=p-;i++)
s2=max(s2,Dfs(lc,i)+Dfs(rc,p-i-)+v[k]);
return f[k][p]=max(s1,s2);
}
void Path(int k,int p)
{
int lc=son[k][],rc=son[k][];
if(rc&&f[rc][p]==f[k][p])
{
falg[k]=;Path(rc,p);return;
}
for(int i=;i<=p-;i++)
{
if(f[k][p]==f[lc][i]+f[rc][p-i-]+v[k])
{
falg[k]=;Path(lc,i);
Path(rc,p-i-);return;
}
}
}
int main()
{
freopen("course.in","r",stdin);
freopen("course.out","w",stdout);
scanf("%d%d",&n,&m);
int x,y;m++;
for(int i=;i<=n;i++)
{
scanf("%d%d",&x,&y);v[i]=y;
if(son[x][]==)son[x][]=i;
else
{
int now=son[x][];
while(son[now][])now=son[now][];
son[now][]=i;
}
}
int ans=Dfs(,m);
printf("%d\n",ans);
Path(,m);
for(int i=;i<=n;i++)
if(falg[i])
printf("%d\n",i);
return ;
}
选课 树形dp+路径输出的更多相关文章
- 选课  树形DP+多叉树转二叉树+dfs求解答案
		
问题 A: 选课 时间限制: 1 Sec 内存限制: 128 MB 题目描述 大 学里实行学分.每门课程都有一定的学分,学生只要选修了这门课并考核通过就能获得相应的学分.学生最后的学分是他选修的各门 ...
 - vijos 1180 选课 树形DP
		
描述 学校实行学分制.每门的必修课都有固定的学分,同时还必须获得相应的选修课程学分.学校开设了N(N<300)门的选修课程,每个学生可选课程的数量M是给定的.学生选修了这M门课并考核通过就能获得 ...
 - 『选课 树形dp 输出方案』
		
这道题的树上分组背包的做法已经在『选课 有树形依赖的背包问题』中讲过了,本篇博客中主要讲解将多叉树转二叉树的做法,以便输出方案. 选课 Description 学校实行学分制.每门的必修课都有固定的学 ...
 - 洛谷P2014 选课 (树形dp)
		
10月1日更新.题目:在大学里每个学生,为了达到一定的学分,必须从很多课程里选择一些课程来学习,在课程里有些课程必须在某些课程之前学习,如高等数学总是在其它课程之前学习.现在有N门功课,每门课有个学分 ...
 - 【CH5104】I-country 线性dp+路径输出
		
pre:在网格中,凸多边形可以按行(row)分解成若干段连续的区间 [ l , r ] ,且左端点纵坐标的值(col)满足先减后增,右端点纵坐标先增后减. 阶段:根据这个小发现,可以将阶段设置成每一行 ...
 - [vijos1880]选课<树形dp>
		
题目链接:https://www.vijos.org/p/1180 这是一道树形dp的裸题,唯一的有意思的地方就是用到了多叉树转二叉树 然后本蒟蒻写这一道水题就是因为以前知道这个知识点但是没有怎么去实 ...
 - [Luogu P2014]选课  (树形DP)
		
题面 传送门:https://www.luogu.org/problemnew/show/P2014 Solution 这是一道十分经典的树形DP题,这种类型的树形DP有一种很普遍的解法. 首先,观察 ...
 - Codevs1378选课[树形DP|两种做法(多叉转二叉|树形DP+分组背包)---(▼皿▼#)----^___^]
		
题目描述 Description 学校实行学分制.每门的必修课都有固定的学分,同时还必须获得相应的选修课程学分.学校开设了N(N<300)门的选修课程,每个学生可选课程的数量M是给定的.学生选修 ...
 - 【洛谷P1854】花店橱窗 线性dp+路径输出
		
题目大意:给定 N 个数字,编号分别从 1 - N,M 个位置,N 个数字按照相对大小顺序放在 M 个位置里,每个数放在每个位置上有一个对答案的贡献值,求一种摆放方式使得贡献值最大. 题解:一道典型的 ...
 
随机推荐
- 【USACO 1.2.1】挤牛奶
			
[问题描述] 三个农民每天清晨5点起床,然后去牛棚给3头牛挤奶.第一个农民在300时刻(从5点开始计时,秒为单位)给他的牛挤奶,一直到1000时刻.第二个农民在700时刻开始,在 1200时刻结束.第 ...
 - JQuery相关的网络资源
			
jquery插件列表 国外网站:http://plugins.jquery.com/ 国内网站:http://www.oschina.net/project/tag/273/jquery
 - [jQuery编程挑战]002:实现一个转盘大抽奖
			
body { background-color: #F2F2F2; text-align: center; } .container { position: relative; width: 500p ...
 - python getpass模块:隐藏不显示输入的密码
			
不知道为什么,本机测试必须要在debug模式下才正常运行.. import getpass #用于隐藏用户输入的字符串,常用来接收密码 def checkuser(user,passwd): ': r ...
 - IIS principle
			
IIS Request | | | Application Pool Config | | | W3WP | | | Many Module | | | AppDomain:这才是.NET的入口 | ...
 - DC DC降壓變換器ic 工作原理
			
目前DC/DC轉化器大致可分為:升壓型dc dc變化器.降壓型dc dc變化器及可升壓又可降壓dc dc變換器.我們今天主要提一下降壓型dc dc變換器的原理: 見下圖降壓變換器原理圖如圖1所示, 當 ...
 - 为什么同时需要IP地址和MAC地址
			
每个以太网设备在出厂时都有一个唯一的MAC地址,为什么还需要为每台主机再分配一个IP地址?或者说每台主机都分配唯一的IP地址,为什么还要在网络设备(如网卡,集线器,路由器等)生产时内嵌一个唯一的MAC ...
 - -_-#【Angular】自定义过滤器
			
AngularJS学习笔记 <!DOCTYPE html> <html ng-app="Demo"> <head> <meta chars ...
 - js接收后台时间数据变成秒处理为正常格式
			
在做项目时,后台数据json传到前台ajax,数据中包含DateTime格式的数据,前台js操作时间数据的时候却发现日期变成了秒格式 js能对日期操作的那些方法均不能使用了,例如getDay()等等, ...
 - 绘图(CGContext)
			
转自 http://blog.csdn.net/zhenyu5211314/article/details/24230581 0 CGContextRef context = UIGraphicsGe ...