Educational Codeforces Round 47 (Rated for Div. 2) G. Allowed Letters
把原字符看成 $X$,每个位置看成 $Y$,每种字符向每个能去的位置连边,就成了一个二分图完美匹配的问题。
现要得到字典序最小,那么就枚举每一位要放什么,然后看放完这种字符,剩下的字符的个数和后面能不能形成完美匹配。
根据霍尔定理,选择 $X$ 中的一个子集 $s$,和 $Y$ 连边的点集为 $N(s)$,那么 $N(s)$ 的大小就只和 $s$ 中的字符种类数有关。
当 $s$ 最大时肯定是每种字符的个数都拿上。那么就用一个 $cnt[i][s]$ 表示后缀 $[i, n]$ 中和 $s$ 连边的位置数。
然后枚举一下子集再判断一下 $N(s)$ 和 $s$ 的关系就行了。
#include <bits/stdc++.h>
using namespace std; const int N = 1e5 + ;
int cnt[N][ << ], cnt2[], bin[N];
char s[N], ans[N]; int main() {
scanf("%s", s + );
int n = strlen(s + );
for (int i = ; i <= n; i++)
cnt2[s[i] - 'a']++;
int m;
scanf("%d", &m);
for (int i = ; i <= m; i++) {
char t[]; int x;
scanf("%d%s", &x, t);
for (int j = ; t[j]; j++)
bin[x] |= ( << (t[j] - 'a'));
}
for (int i = n; i >= ; i--) {
if (bin[i] == ) bin[i] = ( << ) - ;
for (int s = ; s < ( << ); s++) {
cnt[i][s] = cnt[i + ][s];
if (bin[i] & s) cnt[i][s]++;
}
}
for (int i = ; i <= n; i++) {
bool flag = false;
for (int alp = ; alp < ; alp++) {
if (!cnt2[alp] || (bin[i] >> alp & ) == ) continue;
cnt2[alp]--;
bool check = ;
for (int s = ; s < ( << ); s++) {
int cn = ;
for (int j = ; j < ; j++) if (s >> j & )
cn += cnt2[j];
if (cn > cnt[i + ][s]) {
check = false;
break;
}
}
if (check) {
ans[i] = (char)(alp + 'a');
flag = ;
break;
}
cnt2[alp]++;
}
if (!flag) {
puts("Impossible");
return ;
}
}
puts(ans + );
return ;
}
Educational Codeforces Round 47 (Rated for Div. 2) G. Allowed Letters的更多相关文章
- Educational Codeforces Round 47 (Rated for Div. 2)G. Allowed Letters 网络流
		
题意:给你一个字符串,和每个位置可能的字符(没有就可以放任意字符)要求一个排列使得每个位置的字符在可能的字符中,求字典序最小的那个 题解:很容易判断有没有解,建6个点表示从a-f,和源点连边,容量为原 ...
 - Educational Codeforces Round 39 (Rated for Div. 2) G
		
Educational Codeforces Round 39 (Rated for Div. 2) G 题意: 给一个序列\(a_i(1 <= a_i <= 10^{9}),2 < ...
 - Educational Codeforces Round 47 (Rated for Div. 2) 题解
		
题目链接:http://codeforces.com/contest/1009 A. Game Shopping 题目: 题意:有n件物品,你又m个钱包,每件物品的价格为ai,每个钱包里的前为bi.你 ...
 - Educational Codeforces Round 47 (Rated for Div. 2) :E. Intercity Travelling
		
题目链接:http://codeforces.com/contest/1009/problem/E 解题心得: 一个比较简单的组合数学,还需要找一些规律,自己把方向想得差不多了但是硬是找不到规律,还是 ...
 - Educational Codeforces Round 47 (Rated for Div. 2) :D. Relatively Prime Graph
		
题目链接:http://codeforces.com/contest/1009/problem/D 解题心得: 题意就是给你n个点编号1-n,要你建立m条无向边在两个互质的点之间,最后所有点形成一个连 ...
 - Educational Codeforces Round 47 (Rated for Div. 2) :C. Annoying Present(等差求和)
		
题目链接:http://codeforces.com/contest/1009/problem/C 解题心得: 题意就是一个初始全为0长度为n的数列,m此操作,每次给你两个数x.d,你需要在数列中选一 ...
 - Educational Codeforces Round 47 (Rated for Div. 2) :B. Minimum Ternary String
		
题目链接:http://codeforces.com/contest/1009/problem/B 解题心得: 题意就是给你一个只包含012三个字符的字符串,位置并且逻辑相邻的字符可以相互交换位置,就 ...
 - Educational Codeforces Round 47 (Rated for Div. 2) :A. Game Shopping
		
题目链接:http://codeforces.com/contest/1009/problem/A 解题心得: 题意就是给你两个数列c,a,你需要从c中选择一个子串从a头开始匹配,要求子串中的连续的前 ...
 - Educational Codeforces Round 47 (Rated for Div. 2)E.Intercity Travelling
		
题目链接 大意:一段旅途长度N,中间可能存在N-1个休息站,连续走k长度时,疲劳值为a1+a2+...+aka_1+a_2+...+a_ka1+a2+...+ak,休息后a1a_1a1开始计, ...
 
随机推荐
- [转帖]java注解核心知识总结
			
java注解核心知识总结 2019-11-01 20:39:50 从事Java 阅读数 2 收藏 文章标签: java注解总结程序员 更多 分类专栏: java 注解 版权声明:本文为博主原创文 ...
 - SQL中GROUP BY用法示例
			
概述 GROUP BY我们可以先从字面上来理解,GROUP表示分组,BY后面写字段名,就表示根据哪个字段进行分组,如果有用Excel比较多的话,GROUP BY比较类似Excel里面的透视表. GRO ...
 - SQL分类之DML:增删改表中的数据
			
DML:增删改表中的数据 1.添加数据: 语法: insert into 表名(列名1,列名2,...列名n) values(值1,值2,...值n): 注意: 1.列名和值要一一对应. 2.如果表名 ...
 - DRF的APIView、GenericAPIView、GenericViewSet的原理分析
			
一.层次结构 GenericViewSet(ViewSetMixin, generics.GenericAPIView) ---DRF GenericAPIView(views.APIView) -- ...
 - Asp.Net Core中使用GDI+绘图提示gdiplus库找不到的问题
			
参考 https://www.cnblogs.com/VirtualMJ/p/9917916.html 文章中 1 2 3 yum install -y epel-release yum mak ...
 - NetCore 统一处理 webapi 返回null 转为“”
			
数据库中部分表字段允许空值,则代码中实体类对应的字段类型为可空类型Nullable<>,如int?,DateTime?,null值字段序列化返回的值都为null,前端对应字段赋值需要做nu ...
 - 2019 美团java面试笔试题 (含面试题解析)
			
本人5年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.美团等公司offer,岗位是Java后端开发,因为发展原因最终选择去了美团,入职一年时间了,也成为了面试官,之 ...
 - Java自学-异常处理 Throwable
			
Java Throwable类 步骤 1 : Throwable Throwable是类,Exception和Error都继承了该类 所以在捕捉的时候,也可以使用Throwable进行捕捉 如图: 异 ...
 - [Tools] 多媒体视频处理工具FFmpeg
			
FFMpeg FFmpeg是一套可以用来记录.转换数字音频.视频,并能将其转化为流的开源计算机程序.采用LGPL或GPL许可证.它提供了录制.转换以及流化音视频的完整解决方案.它包含了非常先进的音频/ ...
 - JDK 监控和故障处理工具
			
JDK 监控和故障处理工具 JDK 命令行工具 这些命令在 JDK 安装目录下的 bin 目录下: jps (JVM Process Status): 类似 UNIX 的 ps 命令.用户查看所有 J ...