博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
E【中】假的字符串(trie+拓扑排序)
阅读量:5315 次
发布时间:2019-06-14

本文共 797 字,大约阅读时间需要 2 分钟。

题目

做法

一个字符串能作为最小值最基础的条件为不能出现前缀字符串

我们需要确定一种每个字符的排名使得\(s\)作为最小值,另有很多字符串\(t\),与\(s\)第一个不相同的位置可以产生一种偏序限制,如\(s-x,t_y,rk_x<rk_y\)

而判断是否可行直接跑拓扑排序就行

code

#include
typedef int LL;const LL maxn=300009;typedef std::string str;str s[30009],ans[30009];LL nod,n,tot;LL son[maxn][27],val[maxn],du[30];std::vector
to[27];inline void Insert(str t){ LL now(0),len(t.size()); for(LL i=0;i
que;inline bool top_sort(){ LL ret(0); for(LL i=0;i<26;++i) if(!du[i]) que.push(i),ret|=(1<
>s[i]; Insert(s[i]); } for(LL i=1;i<=n;++i) if(Check(s[i])) ans[++tot]=s[i]; printf("%d\n",tot); for(LL i=1;i<=tot;++i) std::cout<
<

转载于:https://www.cnblogs.com/y2823774827y/p/10957932.html

你可能感兴趣的文章
java Map常用方法封装
查看>>
欧几里德与扩展欧几里德算法
查看>>
python中深浅拷贝
查看>>
python中numpy.r_和numpy.c_
查看>>
MySQL关于sql_mode的修改(timestamp的默认值不正确)
查看>>
laravel如何打印orm封装的sql语句
查看>>
大道至简阅读笔记02
查看>>
如何让在panel里的子窗体随panel的大小改变而变化?(转)
查看>>
Concurrent包总结——线程安全的集合操作
查看>>
WPF简单模拟QQ登录背景动画
查看>>
Where to go from here
查看>>
Bitmap和Drawable相互转换方法
查看>>
bzoj 2038 小Z的袜子
查看>>
egret3D与2D混合开发,画布尺寸不一致的问题
查看>>
自定义线程池
查看>>
freebsd 实现 tab 命令 补全 命令 提示
查看>>
numpy调试
查看>>
struts1和struts2的区别
查看>>
函数之匿名函数
查看>>
shell习题第16题:查用户
查看>>