P2763 试题库问题
admin
2024-01-29 12:52:51
0

题目链接:P2763 试题库问题

题意

一个试题库中有 nnn 道试题。每道试题都标明了所属类别。同一道题可能有多个类别属性。现要从题库中抽取 mmm 道题组成试卷。并要求试卷包含指定类型的试题的试题数量要达标。试设计一个满足要求的组卷算法。每道题选出来以后就只能算作一种类型了。

解析

匹配问题之二,一对多的的匹配问题,建图跑网络流。

每道题目可以看做与题的类型配对,每种类型的题有数目的要求。最终我们要选出题目,于是我们考虑将所有题目作为多源汇流向最终的汇点。

n+k+1n + k + 1n+k+1号:源点
n+1n + 1n+1 ~ n+kn + kn+k:代表题目的类型
111 ~nnn:代表nnn道题目
000号:汇点
1.1.1.每道题有多种类型,但最终选出来只能算作一种类型,那么其贡献流向的汇点流量应该为111。
2.2.2.每个题只能只能算作一个题型, 所以 题型 到有 相应题型的题目 的流量为111。
3.3.3.每种题目类型需要cnt道题,所以与源点连边的流量为cntcntcnt。

最终流到汇点的流量大于等于mmm就是可行的
注意边的数量并不算很小,博主自己估算为500050005000还RE了一发,最终开到100001000010000才过。

代码

#include 
#include 
#include 
#include 
using namespace std;
const int N = 2000, M =  10000;
struct edge{int to,nex,w;
}e[M];
int head[N], n, k, m, tot = 1;void add(int to,int from,int w){e[++ tot].w = w;e[tot].to = to;e[tot].nex = head[from];head[from] = tot;
}int dep[N];
bool bfs()
{for(int i = 0; i <= n + k + 1; i ++) dep[i] = 0;dep[n + k + 1] = 1;queueq;q.push(n + k + 1);while(!q.empty()){int u = q.front(); q.pop();for(int i = head[u]; i; i = e[i].nex){int v = e[i].to;if(e[i].w && !dep[v]){dep[v] = dep[u] + 1;if(v == 0) return true;q.push(v);}}}return dep[0];
}int dfs(int u,int inflow){if(u == 0)return inflow;int outflow = 0;for(int i = head[u]; i; i = e[i].nex){int v = e[i].to;if(e[i].w && dep[v] == dep[u] + 1){int flow = dfs(v, min(e[i].w, inflow));e[i].w -= flow;e[i ^ 1].w += flow;inflow -= flow;outflow += flow;}}if(!outflow) dep[u] = 0;return outflow;
}int main()
{ios::sync_with_stdio(false);cout.tie(NULL);cin >> k >> n;// 设0为汇点for(int i = 1; i <= n; i ++){ // 每道题有多种题目类型,但最终只能算作一种,所以每道题到汇点的流量为1add(0, i, 1);add(i, 0, 0);}for(int i = 1; i <= k; i ++){// 设n + k + 1为源点int cnt;cin >> cnt;m += cnt;add(i + n, n + k + 1, cnt);add(n + k + 1, i + n, 0);//需要cnt个,所以与源点连边的流量为cnt}for(int i = 1; i <= n; i ++){int num, x;cin >> num;while(num --){cin >> x; //每个题只能只能算作一个题型, 所以到每道题的流量为1add(i, n + x, 1);add(n + x, i, 0); }}int ans = 0;while(bfs()){ans += dfs(n + k + 1, 10000);}if(ans < m){cout << "No Solution!\n";return 0;}vector res;for(int i = n + 1; i <= n + k; i ++){res.clear();for(int j = head[i]; j; j = e[j].nex){if(e[j].to <= n && e[j].w == 0) res.push_back(e[j].to);}cout << i - n << ": ";for(int x : res){cout << x << " ";}cout << "\n";}return 0;
}

相关内容

热门资讯

原创 4... 写在文章前的声明:在本文之前的说明:本文中所列的投资信息,只是一个对基金资产净值进行排行的客观描述,...
胜宏科技港股大涨49% 做完英... 记者 陈月芹 4月21日,全球AI算力板龙头胜宏科技(02476.HK)登陆港交所,上市首日股价大涨...
永赢基金:聚焦“科技新锐”,科... 数据来源:Wind,时间统计区间为2025/1/1-2026/4/21,指数过往表现不预示未来,不构...
五大阅读趋势显现!当当网发布2... 在第31个世界读书日即将来临之际及首个全民阅读活动周期间,当当网正式发布2026国民阅读洞察报告。 ...
业绩逐季回暖 老百姓大药房一季... 上证报中国证券网讯(记者 夏子航)4月22日晚,老百姓大药房发布2025年年报和2026年一季报。今...
中国20强城市大洗牌:苏州接近... 中国的城市经济竞争格局一直在变化,每年发布的GDP数据都会对城市经济实力进行重新排列。2025年榜又...
直击金宏气体股东会:预期年内氦... 《科创板日报》4月22日讯(记者 郭辉)金宏气体日前举行2025年度股东大会。会上该公司审议了公司年...
5月1日起,俄据悉将叫停哈萨克... 据行业消息人士透露,俄罗斯将于5月1日起停止经友谊管道转运哈萨克斯坦输往德国的石油,相关调整计划已送...
深化具身智能生态布局 京东携手... 4 月 22 日,京东与国内消费级人形机器人头部企业松延动力正式达成三年期战略合作。双方将围绕产品研...
原创 帮... 先问你一个问题,美伊停火今晚到期,按常理避险情绪该升温,黄金应该涨吧?结果恰恰相反——原油涨了,黄金...
300295、600889,将... 三六五网、南京化纤,将被*ST。 公司股票自4月23日开市起停牌一天,于4月24日开市起复牌并实施退...
能源大变天!外媒:羡慕中国的石... 这一次油价突破 110 美元的能源危机,着实魔幻。如果放在十年前,没人会相信中国能在这场风波中获利,...
黄金涨跌两难,现在还能上车吗? 中新网4月22日电(记者 左雨晴) 四月以来,美伊局势反复拉扯,美联储降息预期一变再变。黄金价格在4...
“我身体健康”,库克现身员工大... 当地时间4月21日,受苹果官宣CEO换届影响,公司股价盘中下探超2%,总市值失守4万亿美元关口,收盘...
库克留下一个悬念 工程师能否拯救创新节奏? 听筒Tech(ID:tingtongtech)原创 文 | 赵 森 ...
探索消费信贷与社交支付深度融合... 腾讯这一金融产品再添新功能,4月19日,北京商报记者注意到,微信分付灰度测试转账功能引发热议,在向微...
土耳其主要银行股指早盘下跌2% 每经AI快讯,4月20日,土耳其主要银行股指早盘下跌2%。 每日经济新闻
好用的OTA代运营源头厂家 在如今竞争激烈的酒旅行业中,OTA代运营服务成为了众多酒店、民宿提升竞争力的关键。但市场上的代运营厂...
成都五一出游全国热门第三 “五一”假期临近,同程旅行最新发布的《2026“五一”旅行趋势报告》显示,今年“五一”期间成都同时位...