选课 树形DP+多叉树转二叉树+dfs求解答案
问题 A: 选课
时间限制: 1 Sec 内存限制: 128 MB
题目描述
大 学里实行学分。每门课程都有一定的学分,学生只要选修了这门课并考核通过就能获得相应的学分。学生最后的学分是他选修的各门课的学分的总和。
每个学生都要选择规定数量的课程。其中有些课程可以直接选修,有些课程需要一定的基础知识,必须在选了其它的一些课程的基础上才能选修。例如,《数据结
构》必须在选修了《高级语言程序设计》之后才能选修。我们称《高级语言程序设计》是《数据结构》的先修课。每门课的直接先修课最多只有一门。两门课也可能
存 在相同的先修课。为便于
为 表述每门课都有一个课号,课号依次为 1 ,2 ,3 ,……。下面举例说明
课号 先修课号 学分
1 无 1
2 1 1
3 2 3
4 无 3
5 2 4
上例中 1 是 是 2 的先修课,即如果要选修 2 ,则 1 必定已被选过。同样,如果要选修 3 ,么 那么 1 和 和 2 都一定已被选修过。
学生不可能学完大学所开设的所有课程,因此必须在入学时选定自己要学的课程。每个学生可选课程的总数是给定的。现在请你找出一种选课方案,使得你能得到学分最多,并且必须满足先修课优先的原则。假定课程之间不存在
输入
第一行包括两个正整数 M 、N (中间用一个空格隔开)其中 M 表示待选课程总数(1 ≤M≤500) ,N 表示学生可以选的课程总数(1 ≤N ≤M) 。
下 以下 M 行每行代表一门课,课号依次为 1, ,2, …,M 。每行有两个数(用一个空格隔开),为 第一个数为这门课的先修课的课号(若不存在先修课则该项为 0 ),第二个数为这门课的学分。
输出
第一行只有一个数,即实际所选课程的学分总数。以下 N 行每行有一个数,表示学生所选课程的课号。
样例输入
样例输出
介绍多叉树转二叉树

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<algorithm>
#include<cstring>
#include<queue>
#include<stack>
#include<ctime>
using namespace std;
const int maxn=;
int n,m,root;
int Left[maxn],Right[maxn],w[maxn],f[maxn][maxn];
int dfs(int i,int j)
{
if(i<||j<||i>n+||j>m)return ;
if(f[i][j]!=)return f[i][j];
if(i!=n+)
{
for(int k=;k<j;k++)
f[i][j]=max(f[i][j],dfs(Right[i],k)+dfs(Left[i],j-k-)+w[i]);
f[i][j]=max(f[i][j],dfs(Right[i],j));
}
else f[i][j]=max(f[i][j],dfs(Left[i],j));
return f[i][j];
}
int cnt,p[maxn];
void find(int root,int prize,int s)
{
if(root<||s<||root>n+||s>m)return;
if(root!=n+)
{
if(prize==f[Right[root]][s])
{
find(Right[root],prize,s);
}
else
for(int j=;j<s;j++)
{
if(prize==f[Right[root]][j]+f[Left[root]][s-j-]+w[root])
{
p[++cnt]=root;
if(f[Left[root]][s-j-])find(Left[root],f[Left[root]][s-j-],s-j-);
if(f[Right[root]][j])find(Right[root],f[Right[root]][j],j);
}
}
}
else
{
find(Left[root],f[Left[root]][s],s);
}
return;
}
int main()
{
int i;
scanf("%d%d",&n,&m);
root=n+;
for(i=;i<=n;i++)
{
int dad;
scanf("%d%d",&dad,&w[i]);
if(!dad)dad=root;
Right[i]=Left[dad];
Left[dad]=i;
}
printf("%d\n",dfs(root,m));
find(root,f[root][m],m);
sort(p+,p+cnt+);
for(i=;i<=cnt;i++)
printf("%d\n",p[i]);
return ;
}
选课 树形DP+多叉树转二叉树+dfs求解答案的更多相关文章
- hdu 4044 GeoDefense (树形dp | 多叉树转二叉树)
题目链接:hdu-4044 题意 这是一个塔防游戏,地图是一个n个编号为1-n的节点的树, 节点1是敌人的基地,其他叶子节点都是你的基地. 敌人的基地会源源不断地出来怪兽,为了防止敌人攻进你的基 ...
- 树形DP+(分组背包||二叉树,一般树,森林之间的转换)codevs 1378 选课
codevs 1378 选课 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 学校实行学分制.每门的必修课都有固定的学分 ...
- Codevs1378选课[树形DP|两种做法(多叉转二叉|树形DP+分组背包)---(▼皿▼#)----^___^]
题目描述 Description 学校实行学分制.每门的必修课都有固定的学分,同时还必须获得相应的选修课程学分.学校开设了N(N<300)门的选修课程,每个学生可选课程的数量M是给定的.学生选修 ...
- 洛谷P2014 选课 (树形dp)
10月1日更新.题目:在大学里每个学生,为了达到一定的学分,必须从很多课程里选择一些课程来学习,在课程里有些课程必须在某些课程之前学习,如高等数学总是在其它课程之前学习.现在有N门功课,每门课有个学分 ...
- 『选课 树形dp 输出方案』
这道题的树上分组背包的做法已经在『选课 有树形依赖的背包问题』中讲过了,本篇博客中主要讲解将多叉树转二叉树的做法,以便输出方案. 选课 Description 学校实行学分制.每门的必修课都有固定的学 ...
- [Luogu P2014]选课 (树形DP)
题面 传送门:https://www.luogu.org/problemnew/show/P2014 Solution 这是一道十分经典的树形DP题,这种类型的树形DP有一种很普遍的解法. 首先,观察 ...
- [vijos1880]选课<树形dp>
题目链接:https://www.vijos.org/p/1180 这是一道树形dp的裸题,唯一的有意思的地方就是用到了多叉树转二叉树 然后本蒟蒻写这一道水题就是因为以前知道这个知识点但是没有怎么去实 ...
- vijos 1180 选课 树形DP
描述 学校实行学分制.每门的必修课都有固定的学分,同时还必须获得相应的选修课程学分.学校开设了N(N<300)门的选修课程,每个学生可选课程的数量M是给定的.学生选修了这M门课并考核通过就能获得 ...
- codevs 1378选课 树形DP
#include<cstdio> #include<cstring> #include<algorithm> using namespace std; ],tr[] ...
随机推荐
- session与cookie-----2017-05-08
会话控制:目的是记录不同用户身份. 1.session:有实效性 特点: (1)存在在服务器 (2)每个用户都会存一份 (3)可以存储任意类型的数据 优点:安全性高 缺点:服务器压力过大 2.cook ...
- 山东省第八届ACM省赛游记
Day 1: 凌晨,来了几分兴致,和队友在VJudge上开了一把zoj月赛,WA一发闷一口拿铁,一瓶拿铁 不一会就被喝完了!好气啊!遂开始愉快地打游戏,打着打着,woc,居然3点半了,小睡片 刻,咬上 ...
- hdu 1254 推箱子(搜索)
我写的第一道感觉比较难的搜索 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1254 首先要推箱子的话要满足人能够在箱子旁边,而且人的对面也是可通的. ...
- JAVA的Condition详解
Condition 将 Object 监视器方法(wait().notify()和notifyAll())分解成截然不同的对象,以便通过将这些对象与任意Lock实现组合使用,为每个对象提供多个等待 s ...
- Swift学习笔记(4):字符串
目录: 初始化 常用方法或属性 字符串索引 初始化 创建一个空字符串作为初始值: var emptyString = "" // 空字符串字面量 var anotherEmptyS ...
- 在已经部署svn 服务器上,搭建svn项目 成功版
1.进入svn目录,建立版本库 svnadmin create svntest svntest为svn项目名称 2. hooks/ 目录下新建 post-commit 文件 [钩子脚本] #!/bin ...
- C#总结(三)DataGridView增加全选列
最近的一个winform的项目中,碰到datagridview控件的第一列添加全选的功能,通常这个功能,有两种实现方式:1. 为控件添加DataGridViewCheckBoxColumn来实现,但是 ...
- CodeBlocks
- 使用babel编译es6
起因:开发中慢慢的学习使用es6,但是JavaScript需要浏览器来解析,而不是所有浏览器都支持es6,所以为了兼容es6,需要第三方工具进行编译es6. 工具:node,gulp,gulp-bab ...
- PHP中的函数声明与使用
函数 1. 函数名是标识符之一,只能有字母数字下划线,开头不能是数字: 函数名的命名,必须符合&quo ...