网络流问题 P2763 试题库问题
题目描述
«问题描述:
假设一个试题库中有n道试题。每道试题都标明了所属类别。同一道题可能有多个类别属性。现要从题库中抽取m 道题组成试卷。并要求试卷包含指定类型的试题。试设计一个满足要求的组卷算法。
«编程任务:
对于给定的组卷要求,计算满足要求的组卷方案。
输入输出格式
输入格式:
第1行有2个正整数k和n (2 <=k<= 20, k<=n<= 1000)
k 表示题库中试题类型总数,n 表示题库中试题总数。第2 行有k 个正整数,第i 个正整数表示要选出的类型i的题数。这k个数相加就是要选出的总题数m。接下来的n行给出了题库中每个试题的类型信息。每行的第1 个正整数p表明该题可以属于p类,接着的p个数是该题所属的类型号。
输出格式:
第i 行输出 “i:”后接类型i的题号。如果有多个满足要求的方案,只要输出1个方案。如果问题无解,则输出“No Solution!”。
输入输出样例
- 3 15
- 3 3 4
- 2 1 2
- 1 3
- 1 3
- 1 3
- 1 3
- 3 1 2 3
- 2 2 3
- 2 1 3
- 1 2
- 1 2
- 2 1 2
- 2 1 3
- 2 1 2
- 1 1
- 3 1 2 3
- 1: 1 6 8
- 2: 7 9 10
- 3: 2 3 4 5
说明
感谢 @PhoenixEclipse 提供spj
这个题目和圆桌问题是一样的,所以题解可以看圆桌问题,然后再自己写一下这个
- #include <cstdio>
- #include <cstdlib>
- #include <cstring>
- #include <algorithm>
- #include <queue>
- #include <cmath>
- #include <iostream>
- #include <vector>
- #define inf 0x3f3f3f3f
- using namespace std;
- const int maxn = 1e5 + ;
- int s, t, n, m;
- struct node
- {
- int from, to, cap, flow;
- node(int from=,int to=,int cap=,int flow=):from(from),to(to),cap(cap),flow(flow){}
- };
- vector<node>e;
- vector<int>G[maxn];
- int level[maxn], iter[maxn], head[maxn];
- void add(int u,int v,int c)
- {
- e.push_back(node(u, v, c, ));
- e.push_back(node(v, u, , ));
- int len = e.size();
- G[u].push_back(len - );
- G[v].push_back(len - );
- }
- void bfs(int s)
- {
- memset(level, -, sizeof(level));
- queue<int>que;
- que.push(s);
- level[s] = ;
- while(!que.empty())
- {
- int u = que.front(); que.pop();
- for(int i=;i<G[u].size();i++)
- {
- node &now = e[G[u][i]];
- if(level[now.to]<&&now.cap>now.flow)
- {
- level[now.to] = level[u] + ;
- que.push(now.to);
- }
- }
- }
- }
- int dfs(int u,int v,int f)
- {
- if (u == v) return f;
- for(int &i=iter[u];i<G[u].size();i++)
- {
- node &now = e[G[u][i]];
- if(now.cap>now.flow&&level[now.to]>level[u])
- {
- int d = dfs(now.to, v, min(f, now.cap - now.flow));
- if(d>)
- {
- now.flow += d;
- e[G[u][i] ^ ].flow -= d;
- return d;
- }
- }
- }
- return ;
- }
- int sum = ;
- bool dinic()
- {
- int flow = ;
- while()
- {
- bfs(s);
- if (level[t] < ) return flow==sum;
- memset(iter, , sizeof(iter));
- int f;
- while ((f = dfs(s, t, inf)) > ) flow += f;
- }
- }
- int main()
- {
- cin >> m >> n;
- s = , t = n + m + ;
- for (int i = ; i <= m; i++)
- {
- int x;
- cin >> x;
- add(s, i, x);
- sum += x;
- }
- for (int i = ; i <= n; i++) add(i + m, t, );
- for (int i = ; i <= n; i++)
- {
- int p;
- cin >> p;
- while(p--)
- {
- int q; cin >> q;
- add(q, i, );
- }
- }
- int ans = dinic();
- if (ans == ) printf("No Solution!\n");
- else
- {
- for(int i=;i<=m;i++)
- {
- printf("%d:", i);
- for(int j=;j<G[i].size();j++)
- {
- if(e[G[i][j]^].flow==-)
- {
- printf(" %d", e[G[i][j]].to);
- }
- }
- printf("\n");
- }
- }
- return ;
- }
网络流问题 P2763 试题库问题的更多相关文章
- 【题解】 P2763 试题库问题(网络流)
P2763 试题库问题 考虑一个试题要被加入进答案的集合有什么条件? 是某种类型 只算作一次 就这两种且的限制,所以我们用串联的方式连接"类型点"和"作用点". ...
- P2763 试题库问题(dinic)
P2763 试题库问题 dinic 搞个虚拟源点和汇点,瞎建建边就好辣. 偷张图↓↓ 如果没满流就是无解辣 输出方案咋办呢? 枚举每种类型,蓝后枚举它们的边 如果该边被使用了(通过判断反向边的流量), ...
- Cogs 732. [网络流24题] 试题库(二分图)
[网络流24题] 试题库 ★★ 输入文件:testlib.in 输出文件:testlib.out 评测插件 时间限制:1 s 内存限制:128 MB «问题描述: 假设一个试题库中有n道试题.每道试题 ...
- 洛谷 P2763 试题库问题(网络流24题之一)
题目描述 «问题描述: 假设一个试题库中有n道试题.每道试题都标明了所属类别.同一道题可能有多个类别属性.现要从题库中抽取m 道题组成试卷.并要求试卷包含指定类型的试题.试设计一个满足要求的组卷算法. ...
- COGS732. [网络流24题] 试题库
«问题描述:假设一个试题库中有n道试题.每道试题都标明了所属类别.同一道题可能有多个类别属性.现要从题库中抽取m 道题组成试卷.并要求试卷包含指定类型的试题.试设计一个满足要求的组卷算法.«编程任务: ...
- P2763 试题库问题 (网络流 最大流)
传送门 解题思路 比较简单的网络流,建图还是比较好想的.让源点向试题连流量为1的边,试题向所属类型连流量为1的边,类型向汇点连流量为需要此类试题的边.直接跑最大流,输出答案时找到那些满流的边所对的点. ...
- 网络流24题——试题库问题 luogu 2763
题目描述看:这里 这是我们遇到的第一个要求输出方案的问题 考虑建图然后用最大流思想: 首先由源点向每一道试题连边,容量为1 然后由每一种试题类型向汇点连边,容量为需求量 最后由每一道试题向可能属于的试 ...
- [洛谷P2763]试题库问题
题目大意:有 $k$ 种类型和 $n$ 个题目,每个题目会适应部分类型,第$i$个类型需要$s_i$的题,一道题只能满足一种类型,现要求出满足所有类型的题目的方案 题解:看到匹配,想到网络流,源点向试 ...
- 洛谷P2763 试题库问题(最大流)
题意 $n$道试题,每道题有多种类别属性 抽取$m$道题组成试卷,要求包含指定的类型 输出方案 Sol 又是一道zz网络流 我的构图长这样,$k_i$表示第$i$道试题需要的数量 #include&l ...
随机推荐
- centos 7 linux系统安装 mysql5.7.17(glibc版)
前言:经过一天半的折腾,终于把 mysql 5.7.17 版本安装上了 centos 7 系统上,把能参考的博客几乎都看了一遍,终于发现这些细节问题,然而翻了无数的文章,基本上都没有提到这些,所以小生 ...
- 【bug】----- Git上传文件错误导致本地代码丢失
1.问题描述:通过Git上传本地文件,在git commit操作后本地未上传的代码全部丢失... 2.解决: 第一步:在项目目录下打开Git Bash: 第二步:输入 git reflog 第三步:在 ...
- leetcode — binary-tree-zigzag-level-order-traversal
import java.util.ArrayList; import java.util.Arrays; import java.util.List; /** * Source : https://o ...
- Linux常用监控命令简介 - top
top -hv | -bcisS -d delay -n iterations -p pid [, pid ...] 指令介绍-b : 批次模式运行.-c : 显示执行任务的命令行.-d : 设定延迟 ...
- Jenkins结合.net平台之ftp客户端
上一节我们讲解了如何配置ftp服务端,本节我们讲解如何使用winscp搭建ftp客户端,为什么使用winscp而不是filezilla客户端版,前面我们简单说过,这里不再赘述. 下载winscp以后我 ...
- 【Spring】Autowired原理及与Resource注解区别
Autowired注解 Autowired顾名思义,表示自动注入,如下是Autowired注解的源代码: @Target({ElementType.CONSTRUCTOR, ElementType.M ...
- 安装PackageControl
安装PackageControl 1,到PackageControl官网,查找到相应sublime text的版本安装信息, sublime text 3: import urllib.request ...
- js实现多个倒计时并行 js拼团倒计时
本文是对类似于拼团,多个商品每个都有各自的js倒计时,一开始接到接到这个需求也是头疼了一阵子,如果是在商品列表少的时候完全就可以写成死的,固定的变量,写几个定时器就ok了, 但是这次数据是活的,看一些 ...
- 后端开发者的Vue学习之路(五)
目录 上节内容回顾 使用第三方组件库 如何发起请求 请求错误处理 请求带参 以get的方式带参: 以post的方式带参: 封装处理 请求的配置 axios实例 实现调用自定义函数来发起请求 抽取axi ...
- 散列表(has table、哈希表)
一. 散列表是什么 是包含映射关系的一种数据结构,可以提高查找效率. 二. 散列函数 1)必须是一致的.假设输入一个单词“banana”,映射的数字是1,那么以后每次输入banana都要映射到数字1, ...