题目链接: 传送门

Rank of Tetris

Time Limit: 1000MS     Memory Limit: 32768 K

Description

自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球。为了更好的符合那些爱好者的喜好,Lele又想了一个新点子:他将制作一个全球Tetris高手排行榜,定时更新,名堂要比福布斯富豪榜还响。关于如何排名,这个不用说都知道是根据Rating从高到低来排,如果两个人具有相同的Rating,那就按这几个人的RP从高到低来排。终于,Lele要开始行动了,对N个人进行排名。为了方便起见,每个人都已经被编号,分别从0到N-1,并且编号越大,RP就越高。同时Lele从狗仔队里取得一些(M个)关于Rating的信息。这些信息可能有三种情况,分别是"A > B","A = B","A 

Input

本题目包含多组测试,请处理到文件结束。每组测试第一行包含两个整数N,M(0

Output

对于每组测试,在一行里按题目要求输出

Sample Input

3 3
0 > 1
1 < 2
0 > 2
4 4
1 = 2
1 > 3
2 > 0
0 > 1
3 3
1 > 0
1 > 2
2 < 1

Sample Output

OK
CONFLICT
UNCERTAIN

解题思路:

难点在于" = "的情况,此时把相等的数字用一个集合的根节点表示,如果一次入队入度为零的点大于1则说明拓扑排序序列不唯一,用分叉树去理解的话,就是同一层有多个节点,此时就是信息不完全产生多解,如果需要排序的个数小于所给定的数,那么就是存在环,也就是有冲突。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<vector>
#include<queue>
using namespace std;
const int MAX = 10005;
vector<int>edge[MAX];
int A[MAX],B[MAX],Indegree[MAX],root[MAX];
char str[MAX];
int N,M,sum;

void init()
{
    memset(A,0,sizeof(A));
    memset(B,0,sizeof(B));
    memset(Indegree,0,sizeof(Indegree));
    memset(root,0,sizeof(root));
    for (int i = 0;i < N;i++)
    {
        root[i] = i;
        edge[i].clear();
    }
}

int find(int x)
{
    if (root[x] == x)
        return x;
    else
    {
        return root[x] = find(root[x]);
    }
}

int unite(int x,int y)
{
    x = find(x);
    y = find(y);
    if (x == y)
        return 0;
    root[y] = x;
    return 1;
}

void Topsort()
{
    bool uncertain = false;
    queue<int>que;
    for(int i = 0;i < N;i++)
    {
        if (Indegree[i] == 0 && find(i) == i)  //find(i) = i;避免同一个点被多次使用
        {
            que.push(i);
        }
    }
    while (!que.empty())
    {
        if (que.size() > 1) uncertain = true;
        int val = que.front();
        que.pop();
        sum--;
        for (int i = 0;i < edge[val].size();i++)
        {
            if (--Indegree[edge[val][i]] == 0)
            {
                que.push(edge[val][i]);
            }
        }
    }
    if (sum > 0)  //存在环
    {
        printf("CONFLICT\n");
    }
    else if (uncertain)
    {
        printf("UNCERTAIN\n");
    }
    else
    {
        printf("OK\n");
    }
}

int main()
{
    while (~scanf("%d%d",&N,&M))
    {
        int x,y;
        sum = N;
        init();
        for (int i = 0;i < M;i++)
        {
            scanf("%d %c %d",&A[i],&str[i],&B[i]);
            if (str[i] == '=')
            {
                if (unite(A[i],B[i]))
                    sum--;
            }
        }
        for (int i = 0;i < M;i++)
        {
            if (str[i] == '=')  continue;
            x = find(A[i]);
            y = find(B[i]);
            if (str[i] == '>')
            {
                edge[x].push_back(y);
                Indegree[y]++;
            }
            else if (str[i] == '<')
            {
                edge[y].push_back(x);
                Indegree[x]++;
            }
        }
        Topsort();
    }
    return 0;
}

HDU 1811 Rank of Tetris(拓扑排序+并查集)的更多相关文章

  1. ACM: hdu 1811 Rank of Tetris - 拓扑排序-并查集-离线

    hdu 1811 Rank of Tetris Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & % ...

  2. hdu 1811 Rank of Tetris - 拓扑排序 - 并查集

    自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球. 为了更好的符合那些爱好者的喜好,Lele又想了一个新点子:他将制作一个全球Tetris高手排行榜, ...

  3. hdu1811 Rank of Tetris 拓扑排序+并查集

    这道题是拓扑排序和并查集的综合运用. 由于排行榜是一种从高到低的排序.所以在拓扑排序的时候,如果有一次加入的入度为零的点数大于1,就有变得不确定了(UNCERTAIN). 由于只有一棵树,当树的数量大 ...

  4. Rank of Tetris 拓扑排序+并查集

    Problem Description 自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球. 为了更好的符合那些爱好者的喜好,Lele又想了一个新点子: ...

  5. hdu 1811 Rank of Tetris (拓扑 & 并查集)

    Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  6. HDU 1811 拓扑排序 并查集

    有n个成绩,给出m个分数间的相对大小关系,问是否合法,矛盾,不完全,其中即矛盾即不完全输出矛盾的. 相对大小的关系可以看成是一个指向的条件,如此一来很容易想到拓扑模型进行拓扑排序,每次检查当前入度为0 ...

  7. HDU 1811 Rank of Tetris(并查集按秩合并+拓扑排序)

    Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) T ...

  8. HDU 1811 Rank of Tetris(并查集+拓扑排序 非常经典)

    Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  9. hdu 1811 Rank of Tetris (并查集+拓扑排序)

    Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

随机推荐

  1. Word 打包 zip 并提供下载

    该篇博客记录Java Web项目将word打包zip并提供下载功能的实现和其中遇到的坑,方便后续自己的查看的参照. 1. 后台处理的java 方法 首先将所有的word生成到uploadword目录下 ...

  2. 一些实用的sublime快捷键以及初始设置

    一些常用快捷键 Ctrl + N-------------------新建 Ctrl + F-------------------查找 Ctrl+Shift +k -----------删除一行 Ct ...

  3. Android开发自学笔记—1.1(番外)AndroidStudio常用功能介绍

    一.界面区介绍 1.项目组织结构区,用于浏览项目文件,默认Project以Android组织方式展示. 2.设计区,默认在打开布局文件时为设计模式,可直接拖动控件到界面上实现所见即所得,下方的Desi ...

  4. .Net相关

    Lucene 全文搜索 http://lucenenet.apache.org/ Memcached 分布式缓存 http://memcached.org/ selenium UI自动化测试 http ...

  5. equals()的用法

    比如,两个对象 c1, c2; 那么,c1.equals(c2) == true; 则表示c1, c2两个变量的值是一致的 equals适用于所有对象,这是一种特殊方法 equals这种表现形式我们一 ...

  6. [转]领域驱动设计系列文章(2)——浅析VO、DTO、DO、PO的概念、区别和用处

    原文地址:http://www.blogjava.net/johnnylzb/archive/2010/05/27/321968.html 上一篇文章作为一个引子,说明了领域驱动设计的优势,从本篇文章 ...

  7. iOS开发小技巧--实现将图片保存到本地相册

    一.报错的代码 错误 -- out of bounds 超出界限的意思 *** Terminating app due to uncaught exception 'NSInvalidArgument ...

  8. 【SPOJ 694】Distinct Substrings 不相同的子串的个数

    不会FQ啊,没法评测啊,先存一下代码QAQ 2016-06-16神犇Menci帮我测过AC了,谢谢神犇Menci QwQ #include<cstdio> #include<cstr ...

  9. C#元组示例详解

    元组的概要: 数组合并了相同类型的对象,而元组合并了不同类型的对象.元组起源于函数编程语言(如F#) ,在这些语言中频繁使用元组.在N盯4中,元组可通过.NET Fmmework用于所有的NET语言. ...

  10. JavaScript写一个连连看的游戏

    天天看到别人玩连连看, 表示没有认真玩过, 不就把两个一样的图片连接在一起么, 我自己写一个都可以呢. 使用Javascript写了一个, 托管到github, 在线DEMO地址查看:打开 最终的效果 ...