题目链接: 传送门

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. js 数组去重

    这是一道常见的面试题,最近在做[搜索历史记录]功能也用到,开始用了 indexOf 方法,该方法在 ECMA5才有支持,对于 IE8- 就不支持了. 我们可以自己写一个函数(Array对象的方法都是定 ...

  2. LINQ基础概述

    介绍LINQ基础之前,首说一下LINQ 的历史和LINQ是什么,然后说一下学习 LINQ要了解的东西和 LINQ基础语法   LINQ 的历史 从语言方面的进化 –委托 –匿名方法 –Lambda表达 ...

  3. SQL 性能调优日常积累

    我们要做到不但会写SQL,还要做到写出性能优良的SQL,以下为笔者学习.摘录.并汇总部分资料与大家分享! (1)选择最有效率的表名顺序(只在基于规则的优化器中有效) ORACLE 的解析器按照从右到左 ...

  4. JS之获取属性总结

    嗨,我是沐晴,今天来说说JS中关于获取属性的一些方法和区别.闲话不说,来正题. 首先什么是属性呢,比如input标签,标签中的value id type style等,这些就是属性.我们JS获取属性一 ...

  5. C语言函数sscanf()的用法

    从文件读取数据是一件很麻烦的事,所幸有sscanf()函数. C语言函数sscanf()的用法 sscanf() - 从一个字符串中读进与指定格式相符的数据. 函数原型: int sscanf( st ...

  6. linux安装phpmyadmin

    1 配置好MySQL 后启动mysql (service mysqld start); 2 下载phpmyadmin 包,解压只phpmyadmin (解压命令:zip -r abc.zip abc ...

  7. ueditor1.3.6jsp版在struts2应用中上传图片报"未找到上传文件"解决方案

    摘要: ueditor1.3.6jsp版在struts2应用中上传图片报"未找到上传文件"解决方案 在struts2应用中使用ueditor富文本编辑器上传图片或者附件时,即使配置 ...

  8. Ubuntu 完全卸载Apache2

    安装时候使用的一键安装,很简单 apt-get install apache2 这两天想配置一个lighttpd,但是一直不能成功,今天在公司用虚拟机里面的Ubuntu 配置lighttpd成功了,怀 ...

  9. Android 用代码设置Shape,corners,Gradient

    网上查找资料 记录学习 int strokeWidth = 5; // 3dp 边框宽度 int roundRadius = 15; // 8dp 圆角半径 int strokeColor = Col ...

  10. iOS开发小技巧--TableView Group样式中控制每个section之间的距离

    一.TableView的Group样式中,默认的每个section都有sectionHeader和sectionFooter,只要调整这两个的大小就可以实现section之前的间距扩大或缩小 二.项目 ...