Description:

给定一些木棒,木棒两端都涂上颜色,求是否能将木棒首尾相接,连成一条直线,要求不同木棒相接的一边必须是相同颜色的。

解题思路:

可以用图论中欧拉路的知识来解这道题,首先可以把木棒两端看成节点,把木棒看成边,这样相同的颜色就是同一个节点

问题便转化为:

给定一个图,是否存在“一笔画”经过涂中每一点,以及经过每一边一次。

这样就是求图中是否存在欧拉路Euler-Path。(我才知道这个就是欧拉路径。。。T_T)

由图论知识可以知道,无向图存在欧拉路的充要条件为:

①     图是连通的;  // 用并查集判断就好啦。

②     所有节点的度为偶数,或者有且只有两个度为奇数的节点。

附代码(虽然有点小疑问):

#include<stdio.h>
#include<string.h>
#include<iostream>
#include<string>
#define maxn 500000 + 100
using namespace std;

int fa[maxn];
int du[maxn];
int cnt;

void init()
{
    int i;
    for (i=0; i<maxn; ++i)
    {
        fa[i] = i;
    }
    cnt = 0;
}

int find(int v)
{
    if (fa[v] == v) return v;
    return fa[v] = find(fa[v]);
}

void unin(int x, int y)
{
    int fx = find(x);
    int fy = find(y);
    if (fx != fy)
      fa[fx] = fy;
}

struct trie
{
    trie *next[26];
    int key;
    bool isleaf;
    trie()
    {
        for (int i=0; i<26; ++i)
        {
            next[i] = NULL;
        }
        key = 0;
        isleaf = false;
    }
}Root, Node;

int creatTree(char word[])
{
    trie *p = &Root;
    char *str = word;
    while(*str)
    {
       if (p->next[*str-'a'] == NULL)
        p->next[*str-'a'] = new trie;
       p = p->next[*str-'a'];
       str++;
    }
    if (p->isleaf)
        return p->key;
    else
    {
        p->isleaf = true;
        p->key = cnt++;
        return p->key;
    }
}

int main()
{
    char str1[20], str2[20];
    init();
    while(~scanf("%s%s", str1, str2))
    {
        int a, b;
        a = creatTree(str1);
        b = creatTree(str2);
        du[a]++;   // T_T 还是布吉岛为什么。如果这两种颜色已经属于一个集合了。为什么还要度数++呢。所以。额。
        du[b]++;
        if (find(a) != find(b))
        {
//            du[a]++;
//            du[b]++;
            unin(a, b);
        }
    }
    int temp = 0;
    for (int i=0; i<cnt; ++i)
    {
        if (du[i] % 2)
            temp++;
    }
    if (temp != 0 && temp != 2)
    {
        printf("Impossible\n");
        return 0;
    }
    int ttemp = find(0);
    for (int i=1; i<cnt; ++i)
    {
        if (find(i) != ttemp)
        {
            printf("Impossible\n");
            return 0;
        }
    }
    printf("Possible\n");
    return 0;
}

POJ 2513 字典树+并查集+欧拉路径的更多相关文章

  1. POJ 2513 trie树+并查集判断无向图的欧拉路

    生无可恋 查RE查了一个多小时.. 原因是我N define的是250500 应该是500500!!!!!!!!! 身败名裂,已无颜面对众人.. 吐槽完了 我们来说思路... 思路: 判有向图能否形成 ...

  2. POJ 2513 Colored Sticks(欧拉道路+字典树+并查集)

    http://poj.org/problem?id=2513 题意: 给定一些木棒,木棒两端都涂上颜色,求是否能将木棒首尾相接,连成一条直线,要求不同木棒相接的一边必须是相同颜色的. 思路: 题目很明 ...

  3. nyoj 230/poj 2513 彩色棒 并查集+字典树+欧拉回路

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=230 题意:给你许许多多的木棍,没条木棍两端有两种颜色,问你在将木棍相连时,接触的端点颜色 ...

  4. POJ 2513 无向欧拉通路+字典树+并查集

    题目大意: 有一堆头尾均有颜色的木条,要让它们拼接在一起,拼接处颜色要保证相同,问是否能够实现 这道题我一开始利用map<string,int>来对颜色进行赋值,好进行后面的并查操作以及欧 ...

  5. POJ 2513 Colored Sticks (欧拉回路 + 字典树 +并查集)

    Colored Sticks Time Limit: 5000MS   Memory Limit: 128000K Total Submissions: 27097   Accepted: 7175 ...

  6. poj2513 Colored Sticks —— 字典树 + 并查集 + 欧拉回路

    题目链接:http://poj.org/problem?id=2513 题解:通过这题了解了字典树.用字典树存储颜色,并给颜色编上序号.这题为典型的欧拉回路问题:将每种颜色当成一个点.首先通过并查集判 ...

  7. POJ2513Colored Sticks(欧拉通路)(字典树)(并查集)

                                                             Colored Sticks Time Limit: 5000MS   Memory ...

  8. PKU 2513 Colored Sticks(并查集+Trie树+欧拉路径(回路))

    题目大意: 给定一些木棒,木棒两端都涂上颜色,求是否能将木棒首尾相接,连成一条直线,要求不同木棒相连接的一端必须是同颜色的. 解题思路: 可以用图论中欧拉路的知识来解这道题,首先可以把木棒两端看成节点 ...

  9. [WC2005]双面棋盘(线段树+并查集)

    线段树+并查集维护连通性. 好像 \(700ms\) 的时限把我的常数超级大的做法卡掉了, 必须要开 \(O_2\) 才行. 对于线段树的每一个结点都开左边的并查集,右边的并查集,然后合并. \(Co ...

随机推荐

  1. 探索Java8:Stream的使用

    Java 8 API添加了一个新的抽象称为流Stream,可以让你以一种声明的方式处理数据. Stream 使用一种类似用 SQL 语句从数据库查询数据的直观方式来提供一种对 Java 集合运算和表达 ...

  2. TeeChart缩放

    //缩放的技巧 //首先找到待缩放的区域,例如横轴x1-x2,纵轴y1-y2 //那么待放到的区域就是x=x1;x=x2;y=y1;y=y2;这四条线组成的矩形 //首先确定矩形的左上角的坐标,然后确 ...

  3. npm教程_脚手架原理以及bootstrap引入

    格式:vue init <templateName> <ProjectName> 例子:vue init webpack vue02 运行上面的命令后,脚手架帮忙按照webpa ...

  4. 如何在Twitter开发者平台上注册自己的应用

    1.打开twitter的官网https://dev.twitter.com,如果还没有注册账号的,需要注册账号,已经注册账号的,请先登录:2.选择其中的My apps,如下图: 3.进去界面,选择Cr ...

  5. jquery.cookie.js中$.cookie() 使用方法

    定义:让网站服务器把少量数据储存到客户端的硬盘或内存,从客户端的硬盘读取数据的一种技术: 下载与引入:jquery.cookie.js基于jquery:先引入jquery,再引入:jquery.coo ...

  6. C++作业:Circle_area

    Github链接: Circle_area 代码: main.cpp #include "circle_area.h" #include <iostream> #inc ...

  7. MVC ---- 如何使用Action委托

    先建立一个Serven 类 public class Seven { public static void TestSeven1() { List<User> userList = Fiv ...

  8. linux之cut用法--转载

    cut是一个选取命令,就是将一段数据经过分析,取出我们想要的.一般来说,选取信息通常是针对“行”来进行分析的,并不是整篇信息分析的. (1)其语法格式为:cut  [-bn] [file] 或 cut ...

  9. 常见dos命令汇总

    常用的内部命令有md.cd.rd.dir.path.copy.type.edit.ren.del.cls.ver.date.time.prompt.常用的外部命令有deltree.format.dis ...

  10. Selenium 对窗口对HTML的操作举例