题目描述

«问题描述:

假设一个试题库中有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!”。

输入输出样例

输入样例#1: 复制

  1. 3 15
  2. 3 3 4
  3. 2 1 2
  4. 1 3
  5. 1 3
  6. 1 3
  7. 1 3
  8. 3 1 2 3
  9. 2 2 3
  10. 2 1 3
  11. 1 2
  12. 1 2
  13. 2 1 2
  14. 2 1 3
  15. 2 1 2
  16. 1 1
  17. 3 1 2 3
输出样例#1: 复制

  1. 1: 1 6 8
  2. 2: 7 9 10
  3. 3: 2 3 4 5

说明

感谢 @PhoenixEclipse 提供spj

这个题目和圆桌问题是一样的,所以题解可以看圆桌问题,然后再自己写一下这个

  1. #include <cstdio>
  2. #include <cstdlib>
  3. #include <cstring>
  4. #include <algorithm>
  5. #include <queue>
  6. #include <cmath>
  7. #include <iostream>
  8. #include <vector>
  9. #define inf 0x3f3f3f3f
  10. using namespace std;
  11. const int maxn = 1e5 + ;
  12. int s, t, n, m;
  13. struct node
  14. {
  15. int from, to, cap, flow;
  16. node(int from=,int to=,int cap=,int flow=):from(from),to(to),cap(cap),flow(flow){}
  17. };
  18. vector<node>e;
  19. vector<int>G[maxn];
  20. int level[maxn], iter[maxn], head[maxn];
  21. void add(int u,int v,int c)
  22. {
  23. e.push_back(node(u, v, c, ));
  24. e.push_back(node(v, u, , ));
  25. int len = e.size();
  26. G[u].push_back(len - );
  27. G[v].push_back(len - );
  28. }
  29.  
  30. void bfs(int s)
  31. {
  32. memset(level, -, sizeof(level));
  33. queue<int>que;
  34. que.push(s);
  35. level[s] = ;
  36. while(!que.empty())
  37. {
  38. int u = que.front(); que.pop();
  39. for(int i=;i<G[u].size();i++)
  40. {
  41. node &now = e[G[u][i]];
  42. if(level[now.to]<&&now.cap>now.flow)
  43. {
  44. level[now.to] = level[u] + ;
  45. que.push(now.to);
  46. }
  47. }
  48. }
  49. }
  50.  
  51. int dfs(int u,int v,int f)
  52. {
  53. if (u == v) return f;
  54. for(int &i=iter[u];i<G[u].size();i++)
  55. {
  56. node &now = e[G[u][i]];
  57. if(now.cap>now.flow&&level[now.to]>level[u])
  58. {
  59. int d = dfs(now.to, v, min(f, now.cap - now.flow));
  60. if(d>)
  61. {
  62. now.flow += d;
  63. e[G[u][i] ^ ].flow -= d;
  64. return d;
  65. }
  66. }
  67. }
  68. return ;
  69. }
  70. int sum = ;
  71. bool dinic()
  72. {
  73. int flow = ;
  74. while()
  75. {
  76. bfs(s);
  77. if (level[t] < ) return flow==sum;
  78. memset(iter, , sizeof(iter));
  79. int f;
  80. while ((f = dfs(s, t, inf)) > ) flow += f;
  81. }
  82. }
  83.  
  84. int main()
  85. {
  86. cin >> m >> n;
  87. s = , t = n + m + ;
  88. for (int i = ; i <= m; i++)
  89. {
  90. int x;
  91. cin >> x;
  92. add(s, i, x);
  93. sum += x;
  94. }
  95. for (int i = ; i <= n; i++) add(i + m, t, );
  96. for (int i = ; i <= n; i++)
  97. {
  98. int p;
  99. cin >> p;
  100. while(p--)
  101. {
  102. int q; cin >> q;
  103. add(q, i, );
  104. }
  105. }
  106. int ans = dinic();
  107. if (ans == ) printf("No Solution!\n");
  108. else
  109. {
  110. for(int i=;i<=m;i++)
  111. {
  112. printf("%d:", i);
  113. for(int j=;j<G[i].size();j++)
  114. {
  115. if(e[G[i][j]^].flow==-)
  116. {
  117. printf(" %d", e[G[i][j]].to);
  118. }
  119. }
  120. printf("\n");
  121. }
  122. }
  123. return ;
  124. }

网络流问题 P2763 试题库问题的更多相关文章

  1. 【题解】 P2763 试题库问题(网络流)

    P2763 试题库问题 考虑一个试题要被加入进答案的集合有什么条件? 是某种类型 只算作一次 就这两种且的限制,所以我们用串联的方式连接"类型点"和"作用点". ...

  2. P2763 试题库问题(dinic)

    P2763 试题库问题 dinic 搞个虚拟源点和汇点,瞎建建边就好辣. 偷张图↓↓ 如果没满流就是无解辣 输出方案咋办呢? 枚举每种类型,蓝后枚举它们的边 如果该边被使用了(通过判断反向边的流量), ...

  3. Cogs 732. [网络流24题] 试题库(二分图)

    [网络流24题] 试题库 ★★ 输入文件:testlib.in 输出文件:testlib.out 评测插件 时间限制:1 s 内存限制:128 MB «问题描述: 假设一个试题库中有n道试题.每道试题 ...

  4. 洛谷 P2763 试题库问题(网络流24题之一)

    题目描述 «问题描述: 假设一个试题库中有n道试题.每道试题都标明了所属类别.同一道题可能有多个类别属性.现要从题库中抽取m 道题组成试卷.并要求试卷包含指定类型的试题.试设计一个满足要求的组卷算法. ...

  5. COGS732. [网络流24题] 试题库

    «问题描述:假设一个试题库中有n道试题.每道试题都标明了所属类别.同一道题可能有多个类别属性.现要从题库中抽取m 道题组成试卷.并要求试卷包含指定类型的试题.试设计一个满足要求的组卷算法.«编程任务: ...

  6. P2763 试题库问题 (网络流 最大流)

    传送门 解题思路 比较简单的网络流,建图还是比较好想的.让源点向试题连流量为1的边,试题向所属类型连流量为1的边,类型向汇点连流量为需要此类试题的边.直接跑最大流,输出答案时找到那些满流的边所对的点. ...

  7. 网络流24题——试题库问题 luogu 2763

    题目描述看:这里 这是我们遇到的第一个要求输出方案的问题 考虑建图然后用最大流思想: 首先由源点向每一道试题连边,容量为1 然后由每一种试题类型向汇点连边,容量为需求量 最后由每一道试题向可能属于的试 ...

  8. [洛谷P2763]试题库问题

    题目大意:有 $k$ 种类型和 $n$ 个题目,每个题目会适应部分类型,第$i$个类型需要$s_i$的题,一道题只能满足一种类型,现要求出满足所有类型的题目的方案 题解:看到匹配,想到网络流,源点向试 ...

  9. 洛谷P2763 试题库问题(最大流)

    题意 $n$道试题,每道题有多种类别属性 抽取$m$道题组成试卷,要求包含指定的类型 输出方案 Sol 又是一道zz网络流 我的构图长这样,$k_i$表示第$i$道试题需要的数量 #include&l ...

随机推荐

  1. centos 7 linux系统安装 mysql5.7.17(glibc版)

    前言:经过一天半的折腾,终于把 mysql 5.7.17 版本安装上了 centos 7 系统上,把能参考的博客几乎都看了一遍,终于发现这些细节问题,然而翻了无数的文章,基本上都没有提到这些,所以小生 ...

  2. 【bug】----- Git上传文件错误导致本地代码丢失

    1.问题描述:通过Git上传本地文件,在git commit操作后本地未上传的代码全部丢失... 2.解决: 第一步:在项目目录下打开Git Bash: 第二步:输入 git reflog 第三步:在 ...

  3. leetcode — binary-tree-zigzag-level-order-traversal

    import java.util.ArrayList; import java.util.Arrays; import java.util.List; /** * Source : https://o ...

  4. Linux常用监控命令简介 - top

    top -hv | -bcisS -d delay -n iterations -p pid [, pid ...] 指令介绍-b : 批次模式运行.-c : 显示执行任务的命令行.-d : 设定延迟 ...

  5. Jenkins结合.net平台之ftp客户端

    上一节我们讲解了如何配置ftp服务端,本节我们讲解如何使用winscp搭建ftp客户端,为什么使用winscp而不是filezilla客户端版,前面我们简单说过,这里不再赘述. 下载winscp以后我 ...

  6. 【Spring】Autowired原理及与Resource注解区别

    Autowired注解 Autowired顾名思义,表示自动注入,如下是Autowired注解的源代码: @Target({ElementType.CONSTRUCTOR, ElementType.M ...

  7. 安装PackageControl

    安装PackageControl 1,到PackageControl官网,查找到相应sublime text的版本安装信息, sublime text 3: import urllib.request ...

  8. js实现多个倒计时并行 js拼团倒计时

    本文是对类似于拼团,多个商品每个都有各自的js倒计时,一开始接到接到这个需求也是头疼了一阵子,如果是在商品列表少的时候完全就可以写成死的,固定的变量,写几个定时器就ok了, 但是这次数据是活的,看一些 ...

  9. 后端开发者的Vue学习之路(五)

    目录 上节内容回顾 使用第三方组件库 如何发起请求 请求错误处理 请求带参 以get的方式带参: 以post的方式带参: 封装处理 请求的配置 axios实例 实现调用自定义函数来发起请求 抽取axi ...

  10. 散列表(has table、哈希表)

    一. 散列表是什么 是包含映射关系的一种数据结构,可以提高查找效率. 二. 散列函数 1)必须是一致的.假设输入一个单词“banana”,映射的数字是1,那么以后每次输入banana都要映射到数字1, ...