ctsc选课
CTSC 1997
大学实行学分制。每门课程都有一定的学分,学生只要选修了这门课并通过考核就能获得相应学分。学生最后的学分是他选修各门课的学分总和。
每个学生都要选择规定数量的课程。有些课程可以直接选修,有些课程需要一定的基础知识,必须在选了其他的一些课程基础上才能选修。例如《数据结构》必须在选修了《高级语言程序设计》后才能选修。我们称《高级语言程序设计》是《数据结构》的先修课。每门课的直接先修课最多只有一门。两门课也可能存在相同的先修课。为便于表述,每门课都有一个课号,课号依次为 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,分别表示待选课程数和可选课程数。
接下来 MMM 行每行描述一门课,课号依次为 1,2,⋯,M。每行两个数,依次表示这门课先修课课号(若不存在,则该项值为 0)和该门课的学分。
各相邻数值间以空格隔开。
输出格式
输出一行,表示实际所选课程学分之和。
样例
样例输入
7 4
2 2
0 1
0 4
2 1
7 1
7 6
2 2
样例输出
13
数据范围与提示
1≤N≤M≤100,学分不超过 20。
——————————————————————————————————————————————————————————————————————————————
经典的树上动归
主要有两种方法,一种是转为二叉树,然后动归,但是其中有一点要注意就是f[u][m]=max(f[u][m],dp(tree[u].rc,m));
另一种方法就是树上背包,模板题目,开始不太好懂!注意0号点事不用计入的!
________________________________________________________________________________________________________________________________________
转二叉树动归
1 #include<bits/stdc++.h>
2 using namespace std;
3 const int maxn=1010;
4 int n,m;
5 struct edge
6 {
7 int u,v,nxt;
8 }e[maxn<<1];
9 int head[maxn],js;
10 int val[maxn];
11 void addage(int u,int v)
12 {
13 e[++js].u=u;e[js].v=v;
14 e[js].nxt=head[u];head[u]=js;
15 }
16 void readint(int &x)
17 {
18 x=0;
19 char c=getchar();
20 int f=1;
21 for(;c>'9'||c<'0';c=getchar());
22 for(;c>='0'&&c<='9';c=getchar())x=x*10+c-'0';
23 x*=f;
24 }
25 void writeint(int x)
26 {
27 if(x<0)
28 {
29 putchar('-');
30 x=-x;
31 }
32 if(x>9)writeint(x/10);
33 putchar(x%10+'0');
34 }
35 int f[maxn][maxn];
36 int dp(int u)
37 {
38 for(int i=head[u];i;i=e[i].nxt)
39 {
40 int v=e[i].v;
41 dp(v);
42 for(int j=m;j>=0;--j)
43 for(int k=j;k>=0;--k)
44 f[u][j]=max(f[u][j],f[u][j-k]+f[v][k]);
45 }
46 if(u!=0)
47 for(int i=m;i>0;--i)f[u][i]=f[u][i-1]+val[u];
48 }
49 int main()
50 {
51 readint(m);readint(n);
52 for(register int i=1;i<=m;++i)
53 {
54 int u;
55 readint(u);readint(val[i]);
56 addage(u,i);
57 }
58 dp(0);
59 writeint(f[0][n]);
60 return 0;
61 }
树上背包
1 #include<bits/stdc++.h>
2 using namespace std;
3 const int maxn=1010;
4 int n,m;
5 struct edge
6 {
7 int u,v,nxt;
8 }e[maxn<<1];
9 int head[maxn],js;
10 int val[maxn];
11 void addage(int u,int v)
12 {
13 e[++js].u=u;e[js].v=v;
14 e[js].nxt=head[u];head[u]=js;
15 }
16 void readint(int &x)
17 {
18 x=0;
19 char c=getchar();
20 int f=1;
21 for(;c>'9'||c<'0';c=getchar());
22 for(;c>='0'&&c<='9';c=getchar())x=x*10+c-'0';
23 x*=f;
24 }
25 void writeint(int x)
26 {
27 if(x<0)
28 {
29 putchar('-');
30 x=-x;
31 }
32 if(x>9)writeint(x/10);
33 putchar(x%10+'0');
34 }
35 int f[maxn][maxn];
36 int dp(int u)
37 {
38 for(int i=head[u];i;i=e[i].nxt)
39 {
40 int v=e[i].v;
41 dp(v);
42 for(int j=m;j>=0;--j)
43 for(int k=j;k>=0;--k)
44 f[u][j]=max(f[u][j],f[u][j-k]+f[v][k]);
45 }
46 if(u!=0)
47 for(int i=m;i>0;--i)f[u][i]=f[u][i-1]+val[u];
48 }
49 int main()
50 {
51 readint(m);readint(n);
52 for(register int i=1;i<=m;++i)
53 {
54 int u;
55 readint(u);readint(val[i]);
56 addage(u,i);
57 }
58 dp(0);
59 writeint(f[0][n]);
60 return 0;
61 }
ctsc选课的更多相关文章
- CTSC 选课
题面(有删减) 题目描述 学校实行学分制.每门的必修课都有固定的学分,同时还必须获得相应的选修课程学分.学校开设了N(N<300)门的选修课程,每个学生可选课程的数量M是给定的.学生选修了这M门 ...
- CTSC是啥
洛谷看到一题的难度NOI/NOI+/CTSC 百度一下 CTSC (China Team Selection Competition)为国际信息学奥林匹克竞赛(International Olympi ...
- 从零开始学Python06作业思路:学生选课系统
一,作业要求 选课系统: 管理员: 创建老师:姓名.性别.年龄.资产 创建课程:课程名称.上课时间.课时费.关联老师 学生:用户名.密码.性别.年龄.选课列表[].上课记录{课程1:[di,a,]} ...
- python之选课系统详解[功能未完善]
作业需求 思路:1.先写出大体的类,比如学校类,学生类,课程类-- 2.写出类里面大概的方法,比如学校类里面有创建讲师.创建班级-- 3.根据下面写出大致的代码,并实现其功能 遇到的困 ...
- 第一章-第六题(帮人抢票,帮人选课这些软件是否合法 你怎么看?)--By梁旭晖
我觉得这些软件是合法的,符合道德规范的. 计算机当初设计的初衷就是简化甚至替代人类的工作.而软件作为计算机硬件的驱动着,其设计就是体现这些原则. 现在互联网上的订票,选课类型的网站还是有很多的,比如: ...
- Python开发程序:选课系统-改良版
程序名称: 选课系统 角色:学校.学员.课程.讲师要求:1. 创建北京.上海 2 所学校2. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上海开3. ...
- SQL Server 【附】创建"商品管理数据库"、"学生选课数据库"的SQL语句
附:(创建“商品管理数据库”的SQL语句) --建立"商品管理数据库"数据库-- create database 商品管理数据库 on(name='商品管理数据库_m', file ...
- BFS、DFS与选课问题(拓扑排序)
1选课问题 Leetcode上有这样一道题:有代号0,1,2……n-1的n门课程.其中选择某些课程需要另一些课程作为前提条件.用一组pair来表示这些条件:[1,0],[1,2],表示如果要选修课程1 ...
- Codevs1378选课[树形DP|两种做法(多叉转二叉|树形DP+分组背包)---(▼皿▼#)----^___^]
题目描述 Description 学校实行学分制.每门的必修课都有固定的学分,同时还必须获得相应的选修课程学分.学校开设了N(N<300)门的选修课程,每个学生可选课程的数量M是给定的.学生选修 ...
随机推荐
- 图解 Java 数据结构
图解Java数据结构: 一.链表 Java ListNode https://www.cnblogs.com/easyidea/p/13371863.html 二.栈 ...
- 动态REM
什么是rem? rem是相对于根元素html字体大小来计算的,即( 1rem = html字体大小 ) rem和em区别? rem:(root em,根em)根元素的fort-size的大小计算em: ...
- Light Probes
LightProbes (光照探针,光探测器?) 提供了一种方法用于捕获和使用 穿过场景中空白空间的 光(light)的信息. 和光照贴图相似(lightmaps),Light Probes也存储关于 ...
- eclipse下的jetty远程调试设置
在windows下的jetty远程调试设置1.首先说明的是windows下的jetty是通过命令java -jar start.jar来启动的,因此要想设置成远程调试模式,则要改用命令java -X ...
- .net通过iTextSharp.pdf操作pdf文件实现查找关键字签字盖章
之前这个事情都CA公司去做的,现在给客户做demo,要模拟一下签字盖章了,我们的业务PDF文件是动态生成的所以没法通过坐标定位,只能通过关键字查找定位了. 之前在网上看了许多通多通过查询关键字,然后图 ...
- 基于E-PUCK 2.0多智能体自主协同 高频投影定位系统
群体智能机器人是一种国际前沿的人工智能研究项目,由多个小型机器人组成的集群式解决系统,灵感源于蚂蚁.蜜蜂.鱼等群体生物,在没有统一领导的情况下,也能合作执行大量复杂的任务,比如组建一个图形,再在此基础 ...
- Alpha冲刺--总结随笔
一.项目预期计划 时间 (天) 前端预期计划 完成情况 后端预期计划 完成情况 1-2 前端开始基本页面的设计 完成 整合项目依赖,搭建基本框架,建立数据库 完成 3-5 前端基础页面的实现与完善 完 ...
- Flink学习之路(一)Flink简介
一.什么是Flink? Apache Flink是一个面向分布式数据流处理和批量数据处理的开源计算平台,提供支持流处理和批处理两种类型应用的功能. 二.Flink特点 1.现有的开源计算方案,会把流处 ...
- .NET 调整图片尺寸(Resize)各种方法
本文中如无特别说明 .NET 指 .NET 5或者更高版本,代码同样可用于 .NET Core 前言 调整图片尺寸最常用的场景就是生成缩略图,一般为保持纵横比缩小,如果图片放大会使图片变得模糊,如果确 ...
- P2327 [SCOI2005]扫雷(递推)
题目链接: https://www.luogu.org/problemnew/show/P2327 题目描述 相信大家都玩过扫雷的游戏.那是在一个$n*m$的矩阵里面有一些雷,要你根据一些信息找出雷来 ...