【题目链接】:http://codeforces.com/contest/510/problem/C

【题意】



给你n个字符串;

问你要怎么修改字典序;

(即原本是a,b,c..z现在你可以修改每个字母在字典序中的位置了);

才能使得这n个字符串是字典序升序的;

【题解】



对于第i个字符串;

让他和第i+1..n个字符串比较->j;

找到第一个不同的位置pos;

然后

必然是要

s[i][pos]< s[j][pos]的;

拓扑排序!

即s[i][pos]建一条边指向s[j][pos]

然后做拓扑排序就好;

如果某个串是另外一个串的子串;

则如果s[i]是s[j]的子串,那么可行,否则无解;



【Number Of WA】



0



【完整代码】

#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define ps push_back
#define fi first
#define se second
#define rei(x) cin >> x
#define pri(x) cout << x
#define ms(x,y) memset(x,y,sizeof x) typedef pair<int,int> pii;
typedef pair<LL,LL> pll; const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int MAXC = 26+10;
const int N = 100+10; int a[MAXC][MAXC],n,du[MAXC],cnt=0;
queue <int> dl;
string s[N];
vector <int> ans; int main()
{
//freopen("F:\\rush.txt","r",stdin);
ios::sync_with_stdio(false);
rei(n);
rep1(i,1,n)
rei(s[i]);
rep1(i,1,n)
{
rep1(j,i+1,n)
{
int ma = min(int(s[i].size()),int(s[j].size()));
int pos = -1;
rep1(k,0,ma-1)
if (s[i][k]!=s[j][k])
{
pos = k;
break;
}
if (pos==-1)
{
if (int(s[i].size())>int(s[j].size()))
return pri("Impossible"<<endl),0;
else
continue;
}
int x = s[i][pos]-'a'+1,y = s[j][pos]-'a'+1;
if (a[x][y]) continue;
du[y]++;
a[x][y]=1;
}
}
rep1(i,1,26)
if (du[i]==0)
dl.push(i),cnt++,ans.ps(i);
while (!dl.empty())
{
int x = dl.front();
dl.pop();
rep1(j,1,26)
if (a[x][j])
{
a[x][j] = 0;
du[j]--;
if (du[j]==0)
{
dl.push(j);
ans.ps(j);
cnt++;
}
}
}
if (cnt==26)
rep1(i,0,25)
putchar(ans[i]+'a'-1);
else
return pri("Impossible"<<endl),0;
//printf("\n%.2lf sec \n", (double)clock() / CLOCKS_PER_SEC);
return 0;
}

最新文章

  1. 关于Windows2008服务器设置MIME后仍然无法播放MP4的解决方法
  2. 如何设置Java开发环境
  3. 认识B/S架构
  4. DICOM:Ubuntu14环境下安装dcm4chee+oviyam2.1
  5. APNS IOS PHP 苹果推送
  6. Qt仿Android带特效的数字时钟源码分析(滑动,翻页,旋转效果)
  7. CSS文字超出div或者span时显示省略号
  8. js获取宽度设置thickbox百分比
  9. BT渗透工具使用学习笔记
  10. H5本地储存Web Storage
  11. vs2008将 win32项目改为console项目
  12. light1370 欧拉函数打表
  13. 【BZOJ】3140: [Hnoi2013]消毒
  14. dev16 cxgrid 在DLL里报0地址错
  15. 连接dubbox注册中心的端口默认是20880
  16. Delphi实现RGB色环的代码绘制(XE10.2+WIN764)
  17. 8 -- 深入使用Spring -- 8...2 管理Hibernate的SessionFactory
  18. hadoop hive install (5)
  19. Django(三)url和返回
  20. Java web.xml 配置技巧—动态欢迎页地址

热门文章

  1. 神经网络结构设计指导原则——输入层:神经元个数=feature维度 输出层:神经元个数=分类类别数,默认只用一个隐层 如果用多个隐层,则每个隐层的神经元数目都一样
  2. bzoj1008 [HNOI2008]越狱——快速幂
  3. jsp jquery js 的基本路径获取
  4. IE下a标签会触发window.onbeforeunload的问题
  5. vue-resource 拦截器的使用
  6. Akka源码分析-Actor&amp;ActorContext&amp;ActorRef&amp;ActorCell
  7. 汇编程序45:检测点13.2 (loop指令的中断例程)
  8. ORA-01075: you are currently logged on
  9. 从flappy bird中论优化
  10. 题解报告:hdu 1285 确定比赛名次