病毒&烦人的幻灯片
病毒
描述
有一天,小y突然发现自己的计算机感染了一种病毒!还好,小y发现这种病毒很弱,只是会把文档中的所有字母替换成其它字母,但并不改变顺序,也不会增加和删除字母。
现在怎么恢复原来的文档呢!小y很聪明,他在其他没有感染病毒的机器上,生成了一个由若干单词构成的字典,字典中的单词是按照字母顺序排列的,他把这个文件拷贝到自己的机器里,故意让它感染上病毒,他想利用这个字典文件原来的有序性,找到病毒替换字母的规律,再用来恢复其它文档。
现在你的任务是:告诉你被病毒感染了的字典,要你恢复一个字母串。
输入virus.in
第一行为整数K(≤50000),表示字典中的单词个数。
以下K行,是被病毒感染了的字典,每行一个单词。
最后一行是需要你恢复的一串字母。
所有字母均为小写。输出virus.out
输出仅一行,为恢复后的一串字母。当然也有可能出现字典不完整、甚至字典是错的情况,这时请输出一个0。样例输入
6
cebdbac
cac
ecd
dca
aba
bac
cedab
样例输出
abcde
思路:首先将每相邻的两个字符串进行比较;遇到不同的字母就建立边;
最后进行拓扑排序即可;
只是注意一点不能同时存在两条入度为零的边;
还有就是注意有多个判错,不要遗漏;
#include<iostream>
#include<cstdio>
#include<cstring>
#include<stack>
#include<cstdlib>
#include<cmath>
const int MAXN=;
using namespace std;
string a[MAXN];
int maxnlength;
struct node
{
int u;
int v;
int w;
int next;
}edge[MAXN];
int rudu[MAXN];
int head[MAXN];
int num=;
int ans[];//保存拓扑排序的结果
int now=;
int n;
int maxnchar=;
int map[][];
void topsort()
{
stack<int>s;
for(int i=;i<=maxnchar;i++)
{
if(rudu[i]==)
{
s.push(i);
ans[now]=i;
now++;
}
}
int flag=;
while(s.size()==)
{
if(s.size()>)
{
cout<<"";
exit();
}
int p=s.top();
s.pop();
for(int i=head[p];i!=-;i=edge[i].next)
{
rudu[edge[i].v]--;
if(rudu[edge[i].v]==)
{
s.push(edge[i].v);
ans[now]=edge[i].v;
now++;
}
}
}
} void ppu()
{
edge[num].u=a[j][k]-;
edge[num].v=a[i][k]-;
edge[num].next=head[edge[num].u];
head[edge[num].u]=num++;
rudu[a[i][k]-]++;
flag2=;
map[a[j][k]-][a[i][k]-]=;
}
int main()
{ scanf("%d",&n);
for(int i=;i<=n;i++)head[i]=-;
for(int i=;i<=n;i++)
{
cin>>a[i];
if(a[i].length()>maxnlength)
maxnlength=a[i].length();
for(int j=;j<=a[i].length();j++)
{
if(a[i][j]->maxnchar)
maxnchar=a[i][j]-;
}
}
int flag2=;
for(int i=;i<=n;i++)
{
int j=i-;
for(int k=;k<=min(a[i].length()-,a[j].length()-);k++)
{
if(a[j][k]!=a[i][k])
{
if(map[a[j][k]-][a[i][k]-]==||map[a[i][k]-][a[j][k]-]==)
{
printf("0\n");
exit();
}
ppu();
break;
}
}
}
topsort();
char sr[];
char huiche[];
gets(huiche);
gets(sr);
int l=strlen(sr);
for(int i=;i<=l;i++)
{
if(sr[i]->maxnchar)
{
printf("0\n");
exit();
}
}
for(int i=;i<=l;i++)
{
for(int j=;j<=now-;j++)
{
if(ans[j]==sr[i]-)
{
printf("%c",char(j+));
}
}
}
return ;
}
烦人的幻灯片
题目描述
李教授于今天下午做一个非常重要的演讲。不幸的是他不是一个非常爱整洁的人,他把自己做演讲要用的幻灯片随便堆放在一起。因此,演讲之前他不得不去整理这些幻灯片。做为一个讲求效率的学者,他希望尽可能简单地完成它。情况是这样,教授这次演讲一共要用n张幻灯片(n<=26),这n张幻灯片按照演讲要使用的顺序已经用数字1,2,…,n在上面编上了号。因为幻灯片是透明的,所以我们不能一下子看清每一个数字所对应的幻灯片。
现在我们用大写字母A,B,C,。。。再次把幻灯片依次编上号,如样例所示,我们可以很快发现编号为A的幻灯片是第4张,把它抽出来后我们又可以确定编号为C的幻灯片是第2张,。。。
你的任务是编写一个程序,把幻灯片的数字编号和字母编号对应起来,显然这种对应应该是唯一的;若是出现多种对应的情况或是某些数字编号和字母对应不起来,我们就称对应是无法实现的。
第一行只有一个数n,表示有n张幻灯片,接下来的n行第行包括4个整数Xmin,Xmax,Ymin,Ymax(整数之间用空格分开),为幻灯片的坐标(该区域为幻灯片),这n张幻灯片按其在输入文件中出现的顺序从前到后依次编号为A,B,C,。。。再接下来的n行依次为n个数字编号的坐标X,Y,显然在幻灯片之外是不会有数字的。
(其实是键盘输入了啦)
若是对应可以实现,你的输出应该包括n行,每一行为一个字母和一个数字,中间以一个空格隔开,并且各行以字母的升序排列,注意输出的字母要大写并且顶格;反之,若是对应无法实现,在文件的第一行顶格输出None即可。行首行末无多余空格。
样例输入
4
6 22 10 20
4 18 6 16
8 20 2 18
10 24 4 8
9 15
19 17
11 7
21 11
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
using namespace std; int nb[],map[][],ans[],q[],head=,tail=,n,i,j;
struct qop{int ix,ax,iy,ay;}a[];
struct qup{int x,y;}b[]; int wow()
{
scanf("%d",&n);
for(i=;i<=n;i++)
{
scanf("%d%d%d%d",&a[i].ix,&a[i].ax,&a[i].iy,&a[i].ay);//记录每一张幻灯片的范围
}
for(i=;i<=n;i++)
{
scanf("%d%d",&b[i].x,&b[i].y);//记录数字坐标
for(j=;j<=n;j++)
{ if(b[i].x>a[j].ix&&b[i].x<a[j].ax&&b[i].y>a[j].iy&&b[i].y<a[j].ay)
{ nb[i]++;//遍历一遍看看数字是否可能在幻灯片上 一个数字的位置可能有几张幻灯片
map[i][j]=;}}}//顺便个他们打个标记
int wq=;
for(i=;i<=n;i++)
{ if(nb[i]==)return false;//如果一个数字没有与之对应的 那他在所有的幻灯片之外 就错了
else if(nb[i]==)
{q[tail++]=i;wq=;}//对应数量唯一 那是确定一一对应的家伙,加进队列
// if(wq==0)return false;//如果没有唯一对应的数字与幻灯片 那也错了
}
while(head!=tail)
{
int u=q[head++],t;
for(i=;i<=n;i++)
{
if(map[u][i]==)
{
ans[i]=u;t=i;//把数字和幻灯片对应起来,t代表第几张幻灯片,u就是数字啦
}
}
for(i=;i<=n;i++)
{
if(map[i][t]==)//如果楼上的幻灯片还与其他数字对应,
//而幻灯片又被去掉了,就要把其他数字对应幻灯片的数量减一
{
map[i][t]=;
nb[i]--;
if(nb[i]==)q[tail++]=i;//如果有新的数字只有唯一对应 就入队
}
}
}
for(i=;i<n-;i++)if(q[i])return ;
else return ;
}
void clean(void)
{
memset(nb,,sizeof(nb));
memset(ans,,sizeof(ans));
memset(a,,sizeof(a));
memset(b,,sizeof(b));
memset(q,,sizeof(q));
}
void out()
{
for(i=i;i<=n;i++)
printf("%c%d\n",i+,ans[i]);//强制转换字母
}
int main()
{ clean();
if(wow())out();
else printf("NONE");
return ;
}
病毒&烦人的幻灯片的更多相关文章
- sdibt 1244 烦人的幻灯片
在这个OJ站还没号,暂时没提交,只是过了样例 真不愧是烦人的幻灯片,烦了我一小时 ---更新:OJ测试完毕,AC 烦人的幻灯片问题 Time Limit: 1 Sec Memory Limit: 6 ...
- 【拓扑排序】烦人的幻灯片(slides)
1395:烦人的幻灯片(slides) 时间限制: 1000 ms 内存限制: 65536 KB提交数: 753 通过数: 416 [题目描述] 李教授将于今天下午作一次非常重 ...
- SID1190471 / 烦人的幻灯片 暴力出奇迹 !!!!!!!!!!!!!!!!!!
PID221 / 烦人的幻灯片 ☆ 提交你的代码 查看讨论和题解 你还木有做过哦 我的状态 查看最后一次评测记录 质量还不能统计出来哦~ 题目评价 质量 无 ★★★★★ ★★★★☆ ★ ...
- UVA663 Sorting Slides(烦人的幻灯片)
UVA663 Sorting Slides(烦人的幻灯片) 第一次做到这么玄学的题,在<信息学奥赛一本通>拓扑排序一章找到这个习题(却发现标程都是错的),结果用二分图匹配做了出来 蒟蒻感觉 ...
- VIJOS PID221 / 烦人的幻灯片
暴力出奇迹,学长诚不欺我. PID221 / 烦人的幻灯片 2017-04-14 19:47:08 运行耗时:30 ms 运行内存:12292 KB 查看最后一次评测记录 题目描述 李教授于今天下午 ...
- COGS——T 438. 烦人的幻灯片
http://www.cogs.pro/cogs/problem/problem.php?pid=438 ★☆ 输入文件:slides.in 输出文件:slides.out 简单对比时间限 ...
- PID221 / 烦人的幻灯片☆ x
超详细解释!我都被我自己惊呆了! (这个题目意思我缓冲了很久!一定要读懂题!否则做不出来) 题目不懂就多读呀~ 提交你的代码 查看讨论和题解 题目描述 李教授于今天下午做一个非常重要的演讲.不幸的是他 ...
- iOS 界面 之 EALayout 无需反复编译,可视化实时界面,告别Storyboard AutoLayout Xib等等烦人的工具
http://blog.csdn.net/fatherhui iOS开发,EALayout 无需反复编译,可视化实时界面,告别Storyboard AutoLayout Xib等等烦人的工具 EALa ...
- Jmeter之解决烦人的中文乱码问题
Jmeter是一款国外开源工具,所以就跟LR一样,对中文的支持不是很好,经常会有同学录制脚本后回放或者是发送HTTP请求,看到响应报文里面有乱码! 那如何才能解决这个问题呢?我们分2个情况来分析: 一 ...
随机推荐
- Vue折腾记 - (2)写一个不大靠谱的面包屑组件
先看效果图 我把页面标题和面包屑封装到一起..就不用涉及到组件的通讯了,不然又要去监听路由或者依赖状态去获取 这里写图片描述 疑惑解答: 点击父(也就是折叠菜单)为什么会跑到子菜单第一个 因为我第一个 ...
- DP入门(4)——线性结构上的动态规划
一.最长上升子序列(LIS) 给定n个整数A1,A2,…,An,按从左到右的顺序选出尽量多的整数,组成一个上升子序列(子序列可以理解为:删除0个或多个数,其他数的顺序不变).例如序列1,6,2,3,7 ...
- Spring Data学习(一):初识
目录 前言 添加Spring Data 配置pom.xml 配置数据库相关信息(application.properties) 配置数据库信息 配置自动根据实体类在数据库创建表 创建User.java ...
- SQL Server 监测语句
qs.creation_time, last_execution_time, total_physical_reads, total_logical_reads, total_logical_writ ...
- Java中输入输出流
InputStream:所有字节输入流的所有类的超类. read(byte[] b)从输入流中读取一定数量的字节,并将其存储在缓冲数组b中 reset()将此流重新定位到最后一次对此流调用mark方法 ...
- mysql类型与java类型对应异常场景
MySQL的bigint unsigned类型,对应java的BigInteger类型,在基于mybatis框架时,如果我将bigint unsigned类型的字段的返回放在一个map的返回类型中时. ...
- [NOIP2016]愤怒的小鸟 DP
---题面--- 题解: 首先观察数据范围,n <= 18,很明显是状压DP.所以设f[i]表示状态为i时的最小代价.然后考虑转移. 注意到出发点(0, 0)已经被固定,因此只需要2点就可以确定 ...
- [Leetcode] Path Sum路径和
Given a binary tree and a sum, determine if the tree has a root-to-leaf path such that adding up all ...
- BZOJ 3629 JLOI2014 聪明的燕姿 约数和+DFS
根据约数和公式来拆s,最后再把答案乘出来,我们发先这样的话递归层数不会太大每层枚举次数也不会太多,然而我们再来个剪枝就好了 #include<cstdio> #include<ios ...
- [poj 3261]后缀数组+滑窗最小值
题目链接:http://poj.org/problem?id=3261 这个是可以交叉的重复串,所以用height就可以了,但是题目说让重复k次以上,也就是直接做一个k-1长度的滑窗最小值,从这些最小 ...