随笔分类 -  acm-图论-网络流

最大流、最小割、费用流
摘要:题意 给定N个人,每个人属于一所大学Ai,擅长一个学科Bi,拥有一个能力值Ci。 考虑从N个人中选出一部分人组建一个队伍,如果这个队伍是梦之队,则需要满足如下条件:队伍中任何两个人学校不同,擅长学科不同。 令k为梦之队中最大可能的人数,对任意$i = 1, 2, \do 阅读全文
posted @ 2022-06-08 16:24 pbc的成长之路 阅读(26) 评论(0) 推荐(0) 编辑
摘要:题意 某公司要处理一个周期性的物流问题。有 n 个城市,第 i 个城市在每周的第 j(1j7) 天会生产 aij 吨某种货物,同时需要消耗 bij 吨该种货物。已知每周的产量等于消耗量(即 aij 之和等于 \( 阅读全文
posted @ 2021-02-21 15:29 pbc的成长之路 阅读(139) 评论(0) 推荐(0) 编辑
摘要:题意 有若干个人在数轴上跑步,每个人可能往左跑,也可能往右跑,但是方向不能变。速度是1m/s 现在给定n个报告,每个报告给出t时刻在x位置有人经过。 问至少有多少个人在跑步。 思路 注:坐标旋转公式: \[ (xy) 阅读全文
posted @ 2021-02-20 10:08 pbc的成长之路 阅读(315) 评论(0) 推荐(0) 编辑
摘要:题意 给定实直线 Ln 个开区间组成的集合 I,和一个正整数 k,试设计一个算法,从开区间集合 I 中选取出开区间集合 SI,使得在实直线 L 的任何一点 xS 中包含点 x 的开区间个数不超过 \(k 阅读全文
posted @ 2021-02-19 20:19 pbc的成长之路 阅读(69) 评论(0) 推荐(0) 编辑
摘要:题意 思路 这道题与K取方格数那道题如出一辙,唯一需要改变的就是不能通过的格点需要跳过。 这道题输出方案有点麻烦,这里有一个技巧就是只看上一个格子的出点与下一个格子的入点之间的边,如果这条边的反向边有流量那么可以走,并顺便将其减1 代码 #include <iostream> #includ 阅读全文
posted @ 2021-02-19 19:48 pbc的成长之路 阅读(56) 评论(0) 推荐(0) 编辑
摘要:题意 给定一张航空图,图中顶点代表城市,边代表两个城市间的直通航线。现要求找出一条满足下述限制条件的且途经城市最多的旅行路线。 从最西端城市出发,单向从西向东途经若干城市到达最东端城市,然后再单向从东向西飞回起点(可途经若干城市)。 除起点城市外,任何城市只能访问 1 次。 对于给定的航空图 阅读全文
posted @ 2021-02-19 15:48 pbc的成长之路 阅读(260) 评论(0) 推荐(0) 编辑
摘要:题意 假设有n根柱子,现要按下述规则在这n根柱子中依次放入编号为1,2,3,的球。 每次只能在某根柱子的最上面放球。 在同一根柱子中,任何 2 个相邻球的编号之和为完全平方数。 试设计一个算法,计算出在 n 根柱子上最多能放多少个球。 思路 典型的最小路径点覆盖 阅读全文
posted @ 2021-02-19 10:28 pbc的成长之路 阅读(75) 评论(0) 推荐(0) 编辑
摘要:题意 给定有向图 G=(V,E)。 设 PG 的一个简单路(顶点不相交)的集合。 如果 V 中每个顶点恰好在 P 的一条路上,则称 PG 的一个路径覆盖。 P 中路径可以从 V 的任何一个顶点开始,长度也是任意的,特 阅读全文
posted @ 2021-02-19 09:42 pbc的成长之路 阅读(196) 评论(0) 推荐(0) 编辑
摘要:题意 有个项目需要 N 天才能完成,其中第 i 天至少需要 Ai 个人。 一共有 M 类志愿者可以招募。其中第 i 类可以从第 Si 天工作到第 Ti 天,招募费用是每人 Ci 元。 求能招募足够的志愿者的最少费用。 数据保证一 阅读全文
posted @ 2021-02-18 23:15 pbc的成长之路 阅读(69) 评论(0) 推荐(0) 编辑
摘要:题意 一个餐厅在相继的 N 天里,每天需用的餐巾数不尽相同。假设第 i 天需要 ri 块餐巾 (i=1,2,,N)。 餐厅可以购买新的餐巾,每块餐巾的费用为 p 分;或者把旧餐巾送到快洗部,洗一块需 m 天,其费用为 f 分;或者送 阅读全文
posted @ 2021-02-18 22:00 pbc的成长之路 阅读(73) 评论(0) 推荐(0) 编辑
摘要:题意 在一个NN的矩形网格中,每个格子里都写着一个非负整数。 可以从左上角到右下角安排K条路线,每一步只能往下或往右,沿途经过的格子中的整数会被取走。 若多条路线重复经过一个格子,只取一次。求能取得的整数的和最大是多少。 思路 这道题与数字梯形那道题的第三问很像,区别在于数字梯形是m阅读全文
posted @ 2021-02-18 21:02 pbc的成长之路 阅读(170) 评论(0) 推荐(0) 编辑
摘要:题意 思路 第一问 这m条路径中,每个点只能使用1次,每条边也只能使用1次,获益为经过点的点权和。 这里的费用不是边的费用,而是点的费用,因此可以采用拆点的技巧,即拆成一个入点和一个出点,入点与出点连边,容量是1(因为每个点只能使用一次),费用是点权。 设立虚拟源点S,与第一行的 阅读全文
posted @ 2021-02-18 20:00 pbc的成长之路 阅读(60) 评论(0) 推荐(0) 编辑
摘要:题意 有 n 个沿铁路运输线环形排列的仓库,每个仓库存储的货物数量ai不等。 如何用最少搬运量可以使 n 个仓库的库存数量相同。搬运货物时,只能在相邻的仓库之间搬运。 数据保证一定有解。 思路 这道题与运输问题有一些相似点。可以将这些仓库分成两类,一类是比最终数量多的仓库,另一 阅读全文
posted @ 2021-02-18 19:46 pbc的成长之路 阅读(61) 评论(0) 推荐(0) 编辑
摘要:题意 有 m 个仓库和 n 个零售商店。第 i 个仓库有 ai 个单位的货物;第 j 个零售商店需要 bj 个单位的货物。货物供需平衡,即\sum_^m a_i = \sum_^nb_j。 从第 i 个仓库运送每单位货物到第 j 阅读全文
posted @ 2021-02-18 19:30 pbc的成长之路 阅读(174) 评论(0) 推荐(0) 编辑
摘要:题意 有 n 件工作要分配给 n 个人做。 第 i 个人做第 j 件工作产生的效益为 cij。 试设计一个将 n 件工作分配给 n 个人做的分配方案。 对于给定的 n 件工作和 n 个人,计算最优分配方案和最差分配方案。 阅读全文
posted @ 2021-02-18 11:01 pbc的成长之路 阅读(252) 评论(0) 推荐(0) 编辑
摘要:#include <iostream> #include <cstdio> #include <cstring> #include <algorithm> #include <queue> using namespace std; const int N = 5010, M = 100010, in 阅读全文
posted @ 2021-02-18 09:55 pbc的成长之路 阅读(36) 评论(0) 推荐(0) 编辑
摘要:题意 给定一张无向图,求最少去掉多少个点,可以使图不连通。点数N50 思路 这里引用李煜东《算法竞赛进阶指南》给出的方法。 若无向图不连通,则图中必有两个点不连通,但这两个点是未知的。因此可以枚举源点S和汇点T,然后求去掉多少个点可以使得ST不连通。答案为各次中的最 阅读全文
posted @ 2021-02-18 09:30 pbc的成长之路 阅读(83) 评论(0) 推荐(0) 编辑
摘要:题意 有n个实验,和m种器材。 每个实验都需要若干种器材,做一个实验可以获得pi的收益,配置一个器材需要花费ci 问做哪些实验,可以获得最大收益。 思路 最大获利的推广版,最大权闭合图模板题 代码 #include <iostream> #include <cstdio> #in 阅读全文
posted @ 2021-02-17 16:00 pbc的成长之路 阅读(62) 评论(0) 推荐(0) 编辑
摘要:题意 给定一个01矩阵,其中你可以在 0 的位置放置攻击装置。 每一个攻击装置(x,y)都可以按照“日”字攻击其周围的8个位置 (x1,y2),(x2,y1),(x+1,y2),(x+2,y1), \((x−1,y+2),(x−2,y+1),(x+1,y+2) 阅读全文
posted @ 2021-02-17 15:49 pbc的成长之路 阅读(78) 评论(0) 推荐(0) 编辑
摘要:题意 思路 首先可以发现两个性质: 只有在偶数秒才可以拿宝石 相邻格子的宝石不能都拿到 根据这两条性质,可以发现这是一个二分图最大独立集问题。 对网格构建二分图,即横纵坐标之和为奇数的格点与源点S连容量是宝石价值的边,汇点T与横纵坐标之和为偶数的格点连容量是宝石价值的边。 横纵坐标之和为奇数 阅读全文
posted @ 2021-02-17 15:46 pbc的成长之路 阅读(72) 评论(0) 推荐(0) 编辑

点击右上角即可分享
微信分享提示