101. Domino

time limit per test: 0.25 sec. 

memory limit per test: 4096 KB

Dominoes – game played with small, rectangular blocks of wood or other material, each identified by a number of dots, or pips, on its face. The blocks usually are called bones, dominoes, or pieces and sometimes men, stones, or even cards.

The face of each piece is divided, by a line or ridge, into two squares, each of which is marked as would be a pair of dice...

The principle in nearly all modern dominoes games is to match one end of a piece to another that is identically or reciprocally numbered.

ENCYCLOPÆDIA BRITANNICA

Given a set of domino pieces where each side is marked with two digits from 0 to 6. Your task is to arrange pieces in a line such way, that they touch through equal marked sides. It is possible to rotate pieces changing
left and right side.

Input

The first line of the input contains a single integer N (1 ≤ N ≤ 100) representing the total number of pieces in the domino set. The following N lines describe pieces. Each piece is represented
on a separate line in a form of two digits from 0 to 6 separated by a space.

Output

Write “No solution” if it is impossible to arrange them described way. If it is possible, write any of way. Pieces must be written in left-to-right order. Every of N lines must contains number of current domino piece
and sign “+” or “-“ (first means that you not rotate that piece, and second if you rotate it).

Sample Input

5
1 2
2 4
2 4
6 4
2 1

Sample Output

2 -
5 +
1 +
3 +
4 -

题意是这种:给你一个数字N,告诉你有多少牌,接下来每一行分别代表一张牌,两个数字分别代表正反两面。能够交换数字。比方我是[1,2]。[3。2]那么我就能够先推倒[1,2],然后转下[3,2]变成[2。3]那么就能够推倒[2,3]
如题目sample,output第一行是2 -,那么我就先选第2个[2,4]变成[4,2],然后是5+,就是[2,1],依次下去就能够所有推倒了。当然有些组合是能够推倒有些是不能所有推倒的。

怎么reduce这个题呢?应该非常easy想到一笔画问题。真的是非常easy想到 = =,那么sample input 就转化成

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYWJjZDE5OTI3MTln/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" width="300" height="130" alt="">
就是一个无向欧拉通路(跟回路差点儿相同。仅仅是回路要回到起点)问题
仅仅要奇数度的点的个数为0或者2就能够达成通路,假设是0,那么起点随意选,否则起点要选奇数度点。

所以我们要用DFS
void through(int start, vector<int>& s){
vector<int>e = maps[start];
for(int i = 0;i < e.size();i++){
if(Edges[e[i]].visited)
continue;
else{
Edges[e[i]].visited = true;
if(start == Edges[e[i]].v1){
through(Edges[e[i]].v2, s);
s.push_back(e[i]);
} else {
through(Edges[e[i]].v1, s);
s.push_back(e[i]);
}
}
}
return;
}

最核心的代码在这里,在DFS里有个跟出栈差点儿相同的操作,在这个操作后,我们就把这条路径给加到结果里面去,当然结果里面是逆序的,我们要逆向输出


以下贴出所有代码
#include <iostream>
#include <stdlib.h>
#include <vector>
#include <map> using namespace std; int N = 0;
int occ[7] = {0};
int START = 0; struct Edge{
int v1,v2;
bool visited;
Edge(){};
Edge(int _v1, int _v2, bool _vis){
v1 = _v1;v2 = _v2;visited = _vis;
}
};
struct Edge Edges[110];
map< int , vector<int> >maps; /*
* 返回一个节点的全部边
*/
vector<int> getEdge(int n){
vector<int> set;
for(int i = 0;i < N;i++){
if(n == Edges[i].v1 || n == Edges[i].v2){
set.push_back(i);
}
}
return set;
} void res(int start,vector<int>& s){
for(int i = s.size()-1;i >= 0;i--){
int front = Edges[s[i]].v1;
int back = Edges[s[i]].v2;
if(start == front){
cout << s[i]+1 << " +" << endl;
start = back;
} else {
cout << s[i]+1 << " -" << endl;
start = front;
}
}
} void through(int start, vector<int>& s){
vector<int>e = maps[start];
for(int i = 0;i < e.size();i++){
if(Edges[e[i]].visited)
continue;
else{
Edges[e[i]].visited = true;
if(start == Edges[e[i]].v1){
through(Edges[e[i]].v2, s);
s.push_back(e[i]);
} else {
through(Edges[e[i]].v1, s);
s.push_back(e[i]);
}
}
}
return;
} int main()
{
int front,back;
cin >> N; int index = 0;
while(cin >> front && cin >> back)
{
Edges[index] = Edge(front,back,false);
index++;
occ[front]++;
occ[back]++;
} int odd_pot = 0, start = Edges[0].v1;
for(int i = 0;i < 7;i++){
if(occ[i] % 2 == 1){
odd_pot++;
start = i;
}
maps[i] = getEdge(i);
}
START = start;
if(odd_pot != 0 && odd_pot != 2){
cout << "No solution";
return 0;
} vector<int>results;
through(start,results);
if(results.size() < N)cout << "No solution";
else res(START,results); return 0;
}

sgu101-欧拉回路的更多相关文章

  1. SGU---101 无向图的欧拉回路

    题目链接: https://cn.vjudge.net/problem/SGU-101 题目大意: 给定你n张骨牌,每张牌左右两端有一个数字,每张牌的左右两端数字可以颠倒,找出一种摆放骨牌的顺序,使得 ...

  2. ACM/ICPC 之 混合图的欧拉回路判定-网络流(POJ1637)

    //网络流判定混合图欧拉回路 //通过网络流使得各点的出入度相同则possible,否则impossible //残留网络的权值为可改变方向的次数,即n个双向边则有n次 //Time:157Ms Me ...

  3. [poj2337]求字典序最小欧拉回路

    注意:找出一条欧拉回路,与判定这个图能不能一笔联通...是不同的概念 c++奇怪的编译规则...生不如死啊... string怎么用啊...cincout来救? 可以直接.length()我也是长见识 ...

  4. ACM: FZU 2112 Tickets - 欧拉回路 - 并查集

     FZU 2112 Tickets Time Limit:3000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u P ...

  5. UVA 10054 the necklace 欧拉回路

    有n个珠子,每颗珠子有左右两边两种颜色,颜色有1~50种,问你能不能把这些珠子按照相接的地方颜色相同串成一个环. 可以认为有50个点,用n条边它们相连,问你能不能找出包含所有边的欧拉回路 首先判断是否 ...

  6. POJ 1637 混合图的欧拉回路判定

    题意:一张混合图,判断是否存在欧拉回路. 分析参考: 混合图(既有有向边又有无向边的图)中欧拉环.欧拉路径的判定需要借助网络流! (1)欧拉环的判定:一开始当然是判断原图的基图是否连通,若不连通则一定 ...

  7. codeforces 723E (欧拉回路)

    Problem One-Way Reform 题目大意 给一张n个点,m条边的无向图,要求给每条边定一个方向,使得最多的点入度等于出度,要求输出方案. 解题分析 最多点的数量就是入度为偶数的点. 将入 ...

  8. UVa 12118 检查员的难题(dfs+欧拉回路)

    https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  9. UVA 10054 (欧拉回路) The Necklace

    题目:这里 题意:有一种由彩色珠子连接而成的项链,每个珠子两半由不同颜色(由1到50的数字表示颜色)组成,相邻的两个珠子在接触的地方颜色相同,现在有一些零碎的珠子,确认它是否能 复原成完整的项链. 把 ...

  10. poj2513Colored Sticks(无向图的欧拉回路)

    /* 题意:将两端涂有颜色的木棒连在一起,并且连接处的颜色相同! 思路:将每一个单词看成一个节点,建立节点之间的无向图!判断是否是欧拉回路或者是欧拉路 并查集判通 + 奇度节点个数等于2或者0 */ ...

随机推荐

  1. Controlled Tournament(状态压缩DP)

    Controlled Tournament 题意 n 名选手进行淘汰赛,R[i][j] = 1 表示 i 能胜过 j.要求通过安排淘汰赛使得,m 选手获得最终胜利,问使得比赛数最少的方案数. 分析 设 ...

  2. POJ 2104 K-th Number (划分树)

                                                                K-th Number Time Limit: 20000MS   Memory ...

  3. bzoj 3864: Hero meet devil

    bzoj3864次元联通们 第一次写dp of dp (:з」∠) 不能再颓废啦 考虑最长匹配序列匹配书转移 由于dp[i][j]的转移可由上一行dp[i-1][j-1],dp[i-1][j],dp[ ...

  4. .Net解析html文档类库HtmlAgilityPack完整使用说明

    在前几篇文章中([搜房网房产数据采集程序demo--GeckoWebBrowser实例] )都有提到一个解析html的C#类库HtmlAgilityPack, 今天终于有时间整理一下,并把Demo分享 ...

  5. 理解内存----优化SQL Server内存配置

    http://blog.csdn.net/burgess_liu/article/details/17757655

  6. Matlab梯度下降及正规方程实现多变量的线性回归

    如果需要代做算法,可以联系我...博客右侧有联系方式. 一.相关概念 1.梯度下降 由于Z= X*theta - y是列向量,所以Z'*Z就是平方和连加,就是2范数:如果Z是矩阵呢,那么Z'*Z的对角 ...

  7. [ZZ]机器学习的入门

    转载自: http://www.cnblogs.com/mq0036/p/7131678.html 本篇虽不是这一个月的流水账,但是基本按照下面的思路对着一个月做了一次总结: 什么是机器学习? 机器学 ...

  8. ES6中的Map集合(与java里类似)

    Set类型可以用来处理列表中的值,但是不适用于处理键值对这样的信息结构.ES6也添加了Map集合来解决类似的问题 一.Map集合 JS的对象(Object),本质上是键值对的集合(Hash结构),但是 ...

  9. ElasticSearch 专业术语

    1.Analysis(分析) 分析的过程就是将全文(full text)转换成 术语/分词(terms). 这取决于使用那个分析器,这些短语:“FOO BAR”, “Foo-Bar”, “foo,ba ...

  10. elasticsearch 基础性操作

    1 基础概念 Elasticsearch是一个近实时的系统,从你写入数据到数据可以被检索到,一般会有1秒钟的延时.Elasticsearch是基于Lucene的,Lucene的读写是两个分开的句柄,往 ...