poj 1094 Sorting It All Out (拓扑排序)

poj 1094 Sorting It All Out (拓扑排序)

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

链接:poj 1094

题意:给定一系列关系(仅仅存在大写字母),推断是否存在矛盾,

或无法确定关系。或能够确定唯一的关系

分析:利用拓扑排序。可是须要边输入关系边排序

矛盾:推断是否存在环

确定关系:能找出唯一的拓扑排序

不能确定关系:不存在环,且全部关系处理后,关系仍无法确定

注:假设出现矛盾,则无需推断接下来的关系了

#include<stdio.h>
#include<string.h>
int n,m,vis[30],rd[30],flag[30],map[30][30],cnt;
char t[30];
int tpsort()
{
    int i,j,k,num,mark=1;
    cnt=0;
    memset(vis,0,sizeof(vis)); //标记是否訪问
    for(i=0;i<n;i++)
        if(flag[i]){
            num=0;
            for(j=0;j<n;j++)    //计算入度为0的个数
                if(flag[j]&&!rd[j]&&!vis[j])
                    num++;     
            if(num==0)  //若不存在入度为0结点,则存在环
                return 0;
            if(num>1)   //若入度为0的结点大于1。说明无法确立唯一的拓扑关系
                mark=0;
            for(j=0;j<n;j++){
                if(flag[j]&&!rd[j]&&!vis[j]){
                    t[cnt++]=j+'A';
                    vis[j]=1;
                    break;
                }
            }
            for(k=0;k<n;k++)
                if(map[j][k])
                    rd[k]--;
        }
    if(!mark)
        cnt=0;
    return 1;
}
int main()
{
    int i,j,mark,pos,r[30];
    char s[5];
    while(scanf("%d%d",&n,&m)!=EOF){
        if(m==0&&n==0)
            break;
        mark=1;
        memset(map,0,sizeof(map));
        memset(flag,0,sizeof(flag)); //标记该元素是否存在
        memset(r,0,sizeof(r));
        for(i=1;i<=m;i++){
            scanf("%s",s);
            if(mark==1){
                flag[s[0]-'A']=flag[s[2]-'A']=1;
                if(s[1]=='>'){
                    map[s[2]-'A'][s[0]-'A']=1;  //记录边的关系
                    r[s[0]-'A']++;              //记录入度
                }
                else{
                    map[s[0]-'A'][s[2]-'A']=1;
                    r[s[2]-'A']++;
                }
                for(j=0;j<n;j++)
                    rd[j]=r[j];   //辅助空间。防止过程中拓扑排序将入度改变了
                mark=tpsort(); 
                if(!mark)   
                    pos=i;
                if(mark&&cnt==n){  //当没有出现环且关系都确定
                    mark=2;
                    pos=i;
                    t[cnt]=0;  //字符数组最后附空字符
                }
            }
        }
        if(mark==0)
            printf("Inconsistency found after %d relations.\n",pos);
        else if(mark==1)
            printf("Sorted sequence cannot be determined.\n");
        else if(mark==2)
            printf("Sorted sequence determined after %d relations: %s.\n",pos,t);
    }
    return 0;
}

版权声明:本文博主原创文章。博客,未经同意不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116980.html原文链接:https://javaforall.net

(0)
上一篇 2022年1月12日 下午3:00
下一篇 2022年1月12日 下午3:00


相关推荐

  • 分布式文件存储选型比较[通俗易懂]

    分布式文件存储选型比较[通俗易懂]一、分布式文件存储的来源在这个数据爆炸的时代,产生的数据量不断地在攀升,从GB,TB,PB,ZB.挖掘其中数据的价值也是企业在不断地追求的终极目标。但是要想对海量的数据进行挖掘,首先要考虑的就是海量数据的存储问题,比如Tb量级的数据。谈到数据的存储,则不得不说的是磁盘的数据读写速度问题。早在上个世纪90年代初期,普通硬盘的可以存储的容量大概是1G左右,硬盘的读取速度大概为4.4MB/s.读取一张硬盘大概需要5分钟时间,但是如今硬盘的容量都在1TB左右了,相比扩展了近千倍。但是硬盘的读取速度大概是10

    2022年6月10日
    62
  • 人工智能万亿市场待挖掘

    人工智能万亿市场待挖掘1.新技术革命登场,IT发展焦点将从互联网转向人工智能发轫于2007年的移动互联网浪潮已经席卷全球,极大地改变了我们的生存状态。然而,就在资本市场热切地期待移动互联网催生出更多新应用服务、更多新商业模式的时候,由技术水平不足导致的发展瓶颈已然出现。与此同时,为突破上述瓶颈,新一轮更激动人心、更值得期待的技术革命风暴已经诞生,将成为未来10年乃至更长时间内IT产业发展的焦点,将再次并更加彻底地颠

    2022年6月22日
    82
  • HTTP协议

    当你在浏览器地址栏敲入“http://www.cnblogs.com/”,然后猛按回车,呈现在你面前的,将是博客园的首页了(这真是废话,你会认为这是理所当然的)。作为一个开发者,尤其是web开发人员,

    2022年3月29日
    50
  • 在vue中使用rules对表单字段进行验证

    在vue中使用rules对表单字段进行验证vue 中表单字段验证的写法和方式有多种 本博客介绍三种较为常用的验证方式 1 写在 data 中验证表单内容 表单 el formref rulesForm rules formRules model rulesForm label width 200px el formref rulesForm rules formRules model rulesForm label width 200px

    2026年3月19日
    2
  • 小米音箱+DeepSeek,小爱秒变"贾维斯"!【喂饭级教程】

    小米音箱+DeepSeek,小爱秒变"贾维斯"!【喂饭级教程】

    2026年3月16日
    2
  • 理解的英文_Spring ioc

    理解的英文_Spring ioc前言:这是在慕课网上学习SpringBoot2.0深度实践之核心技术篇时所做的笔记,主要供本人复习之用。目录第一章概要1.1基本使用1.1.1直接运行1.1.2自定义1.2用到的基础技术1.3用到的扩展衍生技术第二章SpringApplication的准备阶段2.1配置SpringBean的来源2.2推断Web应用类型2.3推断引…

    2025年10月16日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号