news 2026/6/24 17:26:27

打卡信奥刷题(2526)用C++实现信奥 P2014 [CTSC1997] 选课

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
打卡信奥刷题(2526)用C++实现信奥 P2014 [CTSC1997] 选课

P2014 [CTSC1997] 选课

题目描述

在大学里每个学生,为了达到一定的学分,必须从很多课程里选择一些课程来学习,在课程里有些课程必须在某些课程之前学习,如高等数学总是在其它课程之前学习。现在有NNN门功课,每门课有若干学分,分别记作s1,s2,⋯ ,sNs_1,s_2,\cdots,s_Ns1,s2,,sN,每门课有一门或没有直接先修课(若课程aaa是课程bbb的先修课即只有学完了课程aaa,才能学习课程bbb)。一个学生要从这些课程里选择MMM门课程学习,问他能获得的最大学分是多少?

题目保证课程安排无冲突。(即不会有aaabbb的先修课,bbb也是aaa的先修课这类情况存在。)

输入格式

第一行有两个整数NNNMMM用空格隔开(1≤N≤300(1 \leq N \leq 300(1N300,1≤M≤300)1 \leq M \leq 300)1M300)

接下来的NNN行,第i+1i+1i+1行包含两个整数kik_ikisis_isikik_iki表示第iii门课的直接先修课,sis_isi表示第iii门课的学分。若ki=0k_i=0ki=0表示没有直接先修课(0≤ki≤N(0 \leq {k_i} \leq N(0kiN,1≤si≤20)1 \leq {s_i} \leq 20)1si20)

数据保证至少存在一个ki=0k_i=0ki=0,即至少一门课无先修课。

输出格式

只有一行,选MMM门课程的最大学分。

输入输出样例 #1

输入 #1

7 4 2 2 0 1 0 4 2 1 7 1 7 6 2 2

输出 #1

13

C++实现

#include<iostream>#include<cstdio>#definemaxn1000usingnamespacestd;intn,m,f[maxn][maxn],head[maxn],cnt;structedge{intto,pre;}e[maxn];inlineintin(){chara=getchar();while(a<'0'||a>'9'){a=getchar();}intt=0;while(a>='0'&&a<='9'){t=(t<<1)+(t<<3)+a-'0';a=getchar();}returnt;}voidadd(intfrom,intto){e[++cnt].pre=head[from];e[cnt].to=to;head[from]=cnt;}voiddp(intnow){// f[now][0]=0;for(inti=head[now];i;i=e[i].pre){intgo=e[i].to;dp(go);for(intj=m+1;j>=1;j--){for(intk=0;k<j;k++){f[now][j]=max(f[now][j],f[go][k]+f[now][j-k]);}}}}intmain(){n=in(),m=in();for(inti=1;i<=n;i++){intfa=in();f[i][1]=in();add(fa,i);}dp(0);printf("%d\n",f[0][m+1]);return0;}

后续

接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 19:46:01

多参数水质监测仪的技术优势与应用场景

水环境质量直接影响生态平衡与人类生产生活。多参数水质监测仪作为水环境管理的核心工具&#xff0c;通过集成多种传感器与智能分析技术&#xff0c;实现对水体多维度、实时化的动态监测。其精准度高、功能全面、适应性强&#xff0c;可广泛应用于饮用水源保护、工业废水监管、…

作者头像 李华
网站建设 2026/6/24 5:53:17

终极FGO助手Chaldea:从材料管理到战斗策略的完整解决方案

终极FGO助手Chaldea&#xff1a;从材料管理到战斗策略的完整解决方案 【免费下载链接】chaldea Chaldea - Yet Another Material Planner and Battle Simulator for Fate/Grand Order aka FGO 项目地址: https://gitcode.com/gh_mirrors/ch/chaldea 还在为FGO复杂的养成…

作者头像 李华
网站建设 2026/6/24 17:46:32

Scoop 全局安装指南

Scoop 全局安装指南 什么是 Scoop 全局安装&#xff1f; Scoop 支持两种安装模式&#xff1a; 本地安装&#xff1a;应用程序安装在用户目录下&#xff08;C:\Users\用户名\scoop&#xff09;&#xff0c;仅当前用户可用全局安装&#xff1a;应用程序安装在系统目录下&#xff…

作者头像 李华