`

南阳理工OJ 99 单词拼接(欧拉通路)

 
阅读更多

连接:http://acm.nyist.net/JudgeOnline/problem.php?pid=99

单词拼接

时间限制:3000 ms  |  内存限制:65535 KB
难度:5
 
描述

给你一些单词,请你判断能否把它们首尾串起来串成一串。

前一个单词的结尾应该与下一个单词的道字母相同。

 

aloha

dog

arachnid

gopher

tiger

rat

 

可以拼接成:aloha.arachnid.dog.gopher.rat.tiger

 

 
输入
第一行是一个整数N(0<N<20),表示测试数据的组数
每组测试数据的第一行是一个整数M,表示该组测试数据中有M(2<M<1000)个互不相同的单词,随后的M行,每行是一个长度不超过30的单词,单词全部由小写字母组成。
输出
如果存在拼接方案,请输出所有拼接方案中字典序最小的方案。(两个单词之间输出一个英文句号".")
如果不存在拼接方案,则输出
***
样例输入
2
6
aloha
arachnid
dog
gopher
rat
tiger
3
oak
maple
elm
样例输出
aloha.arachnid.dog.gopher.rat.tiger
***

 

刚学了欧拉通路准备找题练手,就悲剧的找到了这个。虽然用思想挺简单,但是题目要求要按字典序排列,让我调试的好辛苦啊!最后没有办法还是找了位大牛(PIAOYI)帮忙。

贴下又烂又长的代码:

 

#include<cstdio>
#include<iostream>
#include<string>
#include<cstring>
#include<vector>
#include<queue>
using namespace std;

const int maxcolor=26;
int G[maxcolor+1][maxcolor+1];
vector<string> ans;//存放结果数组
priority_queue<string, vector<string>, greater<string> >mm[maxcolor+1][maxcolor+1];//按字典序排

int abs(int x)
{
    return x>0?x:-x;
}

void euler(int u)
{
    int uu,vv,flag=1;
    while(flag)
    {
        string str="{";//初始化str为最大
        flag=0;
        for(int v=1;v<=maxcolor;v++)//找其中字典序最小的
        {
            if(G[u][v])
            {
                flag=1;
                if(str>mm[u][v].top())
                {
                    str=mm[u][v].top();
                    uu=u;
                    vv=v;
                }
            }
        }
        if(flag)//继续深搜字典序最小的
        {
               mm[uu][vv].pop();
               G[uu][vv]--;
               euler(vv);
               ans.push_back(str);//最小的存在结果数组里面
        }
    }
}

int f()//找起点函数
{
    int ru,chu,res=0,start=0;
    for(int i=1;i<=maxcolor;i++)
    {
        ru=chu=0;
        for(int j=1;j<=maxcolor;j++)
        {
            if(start==0&&G[i][j]!=0)start=i;//如果是欧拉图,起点就是第一个字母最小的那个单词
            chu+=G[i][j];
            ru+=G[j][i];
        }
        res+=abs(chu-ru);
        if(chu>ru)start=i;//如果是半欧拉图,起点就是出度大一点的那个单词
    }
    if(res>2)return -1;//如果不构成欧拉路,就跳出
    return start;
}

int main()
{
//    freopen("Input.txt","r",stdin);
    int T,start;
    string str,term;
    scanf("%d",&T);
    while(T--)
    {
        memset(G,0,sizeof(G));
        int n;
        scanf("%d",&n);
        for(int i=1;i<=26;i++)
              for(int j=1;j<=26;j++)
                     while(!mm[i][j].empty())mm[i][j].pop();
        for(int i=0;i<n;i++)
        {
            cin>>str;
            int len=(int)str.size();
            G[str[0]-'a'+1][str[len-1]-'a'+1]++;//存图,单词的开始为出度点,结尾为入度点
            mm[str[0]-'a'+1][str[len-1]-'a'+1].push(str);
        }
        start=f();
        if(start==-1)
        {
            printf("***\n");
            continue;
        }
        ans.clear();
        euler(start);
        if((int)ans.size()!=n)//如果单词没有找完,说明不连通,就输出***
        {
            printf("***\n");
            continue;
        }
        for(int i=ans.size()-1;i>=0;i--)//输出结果
        {
            if(i!=0)cout<<ans[i]<<".";
            else cout<<ans[i];
        }
        cout<<endl;
    }
    return 0;
}

 

 

 

 

 

 

 

1
7
分享到:
评论

相关推荐

    南阳理工oj离线题库

    南阳理工oj离线题库是为编程爱好者和学习者提供的一种资源,主要用于练习和提高编程技能。这个离线题库通常包含多种类型的编程题目,涵盖了数据结构、算法、计算机科学基础等多个方面。在这个环境中,用户可以不受...

    南阳理工学院OJ_个人AC代码包(Java提交)

    【南阳理工学院OJ_个人AC代码包(Java提交)】是针对Java初学者的一份宝贵资源,它包含了参与ACM国际大学生程序设计竞赛(ICPC)时在南阳理工学院在线评测系统(OJ)上获得正确答案的代码实例。这些代码展示了如何用...

    南阳理工学院OJ第1版解题报告V1.0.pdf

    ### 南阳理工学院OJ第1版解题报告概览 #### 1. A+B Problem 虽然解题思路在报告中被省略,但我们可以推测这是一个基础的数学加法问题,涉及到数字输入与基本算术操作。此类题目旨在测试初学者对编程语言基本输入...

    南阳理工oj stl练习ac代码

    南阳理工学院的OJ(Online Judge)平台为学生提供了丰富的STL练习题目,通过AC(Accepted,表示代码正确通过所有测试用例)的代码,我们可以学习到STL在实际问题解决中的应用。 1. 容器: STL包含多种容器,如...

    湖南理工oj题解(学习用)-共230道题

    【标题】:“湖南理工oj题解(学习用)-共230道题”揭示了这是一个针对湖南理工大学在线编程竞赛平台(Online Judge,简称OJ)的题解集合,包含了230个不同题目。这类资源通常由参赛者或者经验丰富的程序员整理,...

    哈理工oj 1084百步穿杨

    哈理工OJ1084答案哈理工OJ1084答案哈理工OJ1084答案哈理工OJ1084答案哈理工OJ1084答案

    湖南理工学院OJ-小鱼比可爱

    湖南理工学院小鱼比可爱OJ题

    oj刷题 西安理工大学学生在线实验系统编程题答案(超级详细)

    西安理工大学的在线实验系统编程题答案集合是一份非常宝贵的资源,尤其对于正在学习编程和准备在线编程竞赛(Online Judge,简称OJ)的学生而言。这个压缩包文件包含了各种编程题目及其详细解答,可以帮助学习者深入...

    基于Laravel 5.0的OJ题解网站 , 目前涵盖安科OJ,南阳OJ,杭电OJ ,北大OJ,浙大OJ.zip

    【描述】中提到的“目前涵盖安科OJ,南阳OJ,杭电OJ,北大OJ,浙大OJ”意味着这个题解网站已经集成了多个知名OJ平台的题目,用户可以在一个统一的平台上找到这些不同OJ的题目并查看解决方案。安科OJ、南阳OJ、杭电OJ...

    趣味题:柱状图排序 西安理工大学学生在线实验系统 oj

    趣味题:柱状图排序 西安理工大学学生在线实验系统 oj

    竞赛题集南阳OJ部分习题及解答其他oj试题及解答

    竞赛题集南阳OJ部分习题及解答其他oj试题及解答提取方式是百度网盘分享地址

    山东理工大学2016级OJ题1832

    【知识点详解】 1. **C 语言基础**:在这些题目中,主要使用了 C 语言作为编程语言,包括变量声明、输入输出、循环结构、函数定义与调用等基本概念。例如,`scanf` 用于从标准输入读取数据,`printf` 用于输出结果...

    湖南理工学院OJ-阶乘求和-定义函数

    湖南理工学院OJ-阶乘求和-定义函数

    湖南理工学院Oj-等腰三角形-嵌套循环

    湖南理工学院Oj-等腰三角形-嵌套循环

    软件工程课件--厦门理工

    《软件工程:厦门理工学院深度解析》 软件工程是一门涉及软件开发全过程的学科,它不仅关注编程技术,更注重软件开发的系统性、规范性和可维护性。厦门理工学院的这一系列课件,无疑为学习者提供了一个全面了解和...

    杭电OJ单词爬取翻译爬虫

    杭电HDUOJ爬虫脚本,采用Selenium测试框架编写,爬取完后会自动调用百度api翻译

    郑州轻工业oj;C语言200道题压缩包

    郑州轻工业oj;C语言200道题压缩包;郑州轻工业oj;C语言200道题压缩包;郑州轻工业oj;C语言200道题压缩包;郑州轻工业oj;C语言200道题压缩包;郑州轻工业oj;C语言200道题压缩包;郑州轻工业oj;C语言200道题压缩包;...

    hustoj - 流行的OJ系统,跨平台、易安装、有题库

    【标题】"hustoj" 是一款流行的在线判题系统(Online Judge,简称OJ),它主要用于教育和考试场景,支持教学管理和编程竞赛。这款系统以其跨平台、易安装和包含题库的特点受到广泛欢迎。 【核心知识点】 1. **在线...

    OJ平台hustoj

    【OJ平台hustoj】是一个在线编程竞赛(Online Judge)平台的开源实现,它允许用户提交代码并自动运行测试,以验证程序的正确性。这个平台对于教学、技术比赛和编程训练非常有用,帮助学生和程序员提升编程技能。本文...

    湖南理工学院OJ的0-100题解.rar

    【标题】:“湖南理工学院OJ的0-100题解.rar”是一个包含了解决湖南理工学院在线判题系统(Online Judge,简称OJ)前100道编程题目的压缩文件。这类资源通常被用作编程学习者自我提升、训练编程技能的工具,特别是...

Global site tag (gtag.js) - Google Analytics