码迷,mamicode.com
首页 > 其他好文 > 详细

CF290-C

时间:2015-02-11 20:27:00      阅读:112      评论:0      收藏:0      [点我收藏+]

标签:

拓扑排序

给定n个字符串,要求构造一个字母顺序表以至于这n个字符串是按照字典顺序排序好的(两个子串比较大小从最低位开始,字符大的的字符串大,如b>ab)
首先题目只要求构造一个顺序,我们需要只依照给定的n个字符串的字母相对顺序和原字母表的顺序就可以确定新的顺序.这样很容易就想到拓扑排序
我们默认从1~n的字符串已经是有序的了.
依次比较相邻的两个字符串,将不满足大小顺序的字母在拓扑图上表示
如代码中的:indegree[k2]++; graph[k1].push_back(k2);意味着k1顺序应该在k2之前
遍历所有的字符串后意味着顺序已经确定好,输出就可以了
#include <iostream>
#include <string.h>
#include <vector>

int indegree[200];
int use[200];
using namespace std;
vector<int> graph[200];
vector<int> res;
void topsort()
{
    while(true)
    {
        for(int i=0;i<26;i++)
        {
            if(indegree[i]==0&&graph[i].size()==0&&!use[i])
            {
                use[i]=1;
                res.push_back(i);
            }
        }
        int k=0;
        for(;k<26;k++)
        {
            if(indegree[k]==0&&!use[k])
                break;
        }
        if(k<26)
        {
            use[k]=1;
            res.push_back(k);
            for(int i=0;i<graph[k].size();i++)
            {
                indegree[graph[k].at(i)]--;
            }
            graph[k].clear();
        }
        else
        {
            if(res.size()==26)
                break;
            cout<<"Impossible"<<endl;
            return ;
        }
    }
    for(int i=0;i<res.size();i++)
    {
        cout<<char(res.at(i)+a);
    }
    cout<<endl;
}
int main()
{
    int n;
    memset(use,0,sizeof(use));
    memset(indegree,0,sizeof(indegree));
    char str[200][200];
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>str[i];
    }
    for(int i=2;i<=n;i++)
    {
        char s1[200];
        char s2[200];
        strcpy(s1,str[i-1]);
        strcpy(s2,str[i]);
        int k1=-1;
        int k2=-1;
        for(int j=0;j<min(strlen(s1),strlen(s2));j++)
        {
            if(s1[j]==s2[j])
            {
                continue;
            }
            else
            {
                k1=s1[j]-a;
                k2=s2[j]-a;
                break;
            }
        }
        if(k1==-1)
        {
            if(strlen(s1)>strlen(s2))
            {
                cout<<"Impossible"<<endl;
                return 0;
            }
            else
                continue;
        }
        indegree[k2]++;
        graph[k1].push_back(k2);
    }
    topsort();
    return 0;
}

 

CF290-C

标签:

原文地址:http://www.cnblogs.com/wzsblogs/p/4286870.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!