1182 : 欧拉路·三

这时题目中给的提示:

小Ho:是这种。每次转动一个区域不是相当于原来数字去掉最左边一位,并在最后加上1或者0么。

于是我考虑对于"XYYY",它转动之后能够变成"YYY0"或者"YYY1"。我就将全部的数字0~2^N-1看作2^N个点。连接全部的("XYYY","YYY0"),("XYYY","YYY1")。

比方当N=3时,我得到了这样一个图:

我要做的就是找一条路径,从一个点出发,走过全部的点后。再回到起点。可是我发现好像非常难的样子。

小Hi:那当然了。

你这样构造出来的路径叫做哈密顿回路。不是那么easy能够求解的。

小Ho:哎??那我应该怎么做。

小Hi:事实上你的想法是没问题的,可是须要进行一下变换。在你的构图中我们是用点来表示数字,所以须要经过每个点。假设我们用边来表示每个数字呢?

小Ho:怎么用边表示数字?

小Hi:事实上也非常easy。比方说数字"10011",分别删掉它第一个数字和最后一个数字。得到"1001","0011"。然后我们连接一条从"1001"到"0011"的有向边。表示数字"10011"。则我们能够得到构图的方法:

对于N。我们构造一个包括2^(N-1)个点和2^N条边的图。点的编号从0到2^(N-1)-1。编号为i的点表示数字i。对于随意两个点,假设点i,点j满足点i的后n-2个数字和点j的前n-2个数字同样,则我们连接有向边(i,j)。而边(i,j)表示了数字((i << 1)+(j & 1))。比方对于N=3的时候,我们能够得到:

能够非常easy证明对于随意不同边(i,j),其表示的数字一定不同。

小Ho:这样构图话。仅仅要找到一条欧拉回路就能够了。可是一定会有欧拉回路么?

小Hi:当然能了。对于有向图,其存在欧拉路的条件是,至多有两个点的入度不等于出度。且这两个点满足:当中一个点入度比出度多1,还有一个点出度比入度多1。

若全部点的入度都等于出度。则一定存在欧拉回路。这能够通过和无向图欧拉路相同的方法进行构造证明。

而我们构造的图。由构造方法能够知道对于随意一个点。其入度一定为2,出度一定为2。

所以它必然存在欧拉回路。

在有向图中找欧拉路的方法,也仍然能够使用Fleury算法。写成伪代码的话:

DFS(u):
While (以u为起点。且未被删除的边e(u,v))
删除边e(u,v)
DFS(v)
End
PathSize ← PathSize + 1
Path[ PathSize ] ← u

可是。有一点要注意。在使用Fleury算法计算有向图的欧拉路时。我们须要将path[]倒序输出才干得到正确的路径。

小Ho:那找到欧拉回路之后呢?

小Hi:找到欧拉回路之后仅仅要对该条欧拉回路进行拼接就能够得到我们目标的圆盘状态了。

小Ho:好。我大概明确了。我这就来试试!

题目分析:

提示中说的非常清楚: 好好看看上面的解说。 非常聪明的地方是把图一变成了图二(图二也就是用边表示n位二进制能够表示的全部数。

n=3时, 是0~7),节省了空间。

假设存在一个欧拉回路, 也就是存在一条路径每条边都走过而且仅仅走一遍。 最后回到原点, 那么就能够说这个转盘能够表示n位二进制能够表示的全部数。用fleury求路径。 边球路径边记录,fleury不明确点这里

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string.h>
#include<algorithm>
#include<math.h>
#include<vector>
using namespace std; int n, top, key, final[40000], ans[40000];
vector<int> vec[17000]; void init()//初始化把全部边标记出来
{
for(int i = 0; i < (1 << n - 1); i++)
{
int j = i << 1; // 点i向左移一位
int t = 1 << (n - 1);
j = j & (t - 1);//舍去第一位
vec[i].push_back(j); //最后一位加0
vec[i].push_back(j+1); //最后一位添1
}
}
void dfs(int x)
{
ans[++top] = x;
if(vec[x].size() > 0)
{
int tmp = vec[x][0];
vec[x].erase(vec[x].begin()+0);//要记得删除便利过的点
dfs(tmp);
}
}
void fleury(int x)
{
top = 1;
ans[top] = x;
while(top > 0)
{
if(vec[ans[top]].size() > 0)//假设可扩展。 则dfs可扩展的哪条路线
{
top--;
dfs(ans[top+1]);
}
else//该点x没有其它的边能够先走了(即不可扩展), 那么就用final记录下来
{
final[++key] = ans[top];
//ans仅仅是记录路径的中间记录, 可能会变, 一定要用final做最后的记录
top--;
}
}
}
int main()
{
while(scanf("%d", &n) != EOF)
{
for(int i = 0; i < (1 << n); i++) vec[i].clear();
init();
key = 0;
fleury(0);
for(int i = 1; i <= (1 << n); i++)//将路径的每一个值的最后一个二进制的值求出就可以
{
int tmp = final[i] & 1;
printf("%d", tmp);
}
cout << endl;
}
return 0;
}

hiho 1182 : 欧拉路&#183;三的更多相关文章

  1. hiho 1182 : 欧拉路·三

    1182 : 欧拉路·三 这时题目中给的提示: 小Ho:是这样的,每次转动一个区域不是相当于原来数字去掉最左边一位,并在最后加上1或者0么. 于是我考虑对于"XYYY",它转动之后 ...

  2. hihoCoder #1182 欧拉路·三 (变形)

    题意: 写出一个环,环上有2^n个格子,每个格子中的数字是0或1,相连着的n个格子可以组成一个数的二进制,要求给出这2^n个数字的序列,使得组成的2^n个数字全是不同的.(即从0到2^n-1) 思路: ...

  3. hiho一下 第四十九周 欧拉路&#183;一

    [题目链接]:click here~~ 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描写叙述 小Hi和小Ho近期在玩一个解密类的游戏.他们须要控制角色在一片原始丛林里面探险 ...

  4. hiho欧拉路·二 --------- Fleury算法求欧拉路径

    hiho欧拉路·二 分析: 小Ho:这种简单的谜题就交给我吧! 小Hi:真的没问题么? <10分钟过去> 小Ho:啊啊啊啊啊!搞不定啊!!!骨牌数量一多就乱了. 小Hi:哎,我就知道你会遇 ...

  5. hiho一下 第四十九周 题目1 : 欧拉路·一【无向图 欧拉路问题】

    题目1 : 欧拉路·一 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho最近在玩一个解密类的游戏,他们需要控制角色在一片原始丛林里面探险,收集道具,并找到最 ...

  6. hiho一下 第四十九周 欧拉路

    http://hihocoder.com/contest/hiho49/problem/1 给定无孤立结点图G,若存在一条路,经过图中每边一次且仅一次,该条路称为欧拉路. 一个无向图存在欧拉路当且仅当 ...

  7. hiho48 : 欧拉路·一

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho最近在玩一个解密类的游戏,他们需要控制角色在一片原始丛林里面探险,收集道具,并找到最后的宝藏.现在他们控制的 ...

  8. 牛客练习赛40 C 小A与欧拉路(树的直径)

    链接:https://ac.nowcoder.com/acm/contest/369/C 题目描述 小A给你了一棵树,对于这棵树上的每一条边,你都可以将它复制任意(可以为0)次(即在这条边连接的两个点 ...

  9. [hihoCoder] 第四十九周: 欧拉路·一

    题目1 : 欧拉路·一 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho最近在玩一个解密类的游戏,他们需要控制角色在一片原始丛林里面探险,收集道具,并找到最 ...

随机推荐

  1. 转:Java读写文件各种方法及性能比较

    干Java这么久,一直在做WEB相关的项目,一些基础类差不多都已经忘记.经常想得捡起,但总是因为一些原因,不能如愿. 其实不是没有时间,只是有些时候疲于总结,今得空,下定决心将丢掉的都给捡起来. 文件 ...

  2. 【Docker自定制镜像之Dockerfile】

    镜像的定制,就是定制每一层所添加的配置.文件,如果可以把每一层修改.安装.构建.操作的命令都写入到一个脚本中,用脚本来构建.定制镜像,这个脚本就是Dockerfile Dockerfile是一个文本文 ...

  3. SpringBoot常用注解的介绍及使用 - 转载

    常用注解 @springBootApplication 系统启动类注解,此注解是个组合注解,包括了:@SpringBootConfiguration,@EnableAutoConfiguration, ...

  4. Vijos——T1053 Easy sssp

    https://vijos.org/p/1053 描述 输入数据给出一个有N(2 <= N <= 1,000)个节点,M(M <= 100,000)条边的带权有向图. 要求你写一个程 ...

  5. 生成ssh公有密钥而且注冊到Github Generate ssh rsa keys and register public key on Github

    私有密钥和公有密钥是成对的两个文件,私有文件保存在自己的本机,公有密钥保存到还有一端的server,站点等. github就是一种站点. 仅仅有保存了私有密钥的机器才干訪问远程的server等. 使用 ...

  6. android中9-patch图片的使用

    看了非常多文章的介绍,9.png图片有两种区域:可扩展区和内容显示区. 弄了半天才明确什么叫做可扩展区,什么叫做内容显示区. 分享一下自己的理解. 下图是某博客的截图: 图片来自:http://blo ...

  7. js02---字符串

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  8. .Net 自动属性结合手动属性

    Model using System; using System.Collections.Generic; using System.Linq; using System.Web; namespace ...

  9. 浏览器加载跟渲染html的顺序-css渲染效率的探究

    1.浏览器加载和渲染html的顺序1.IE下载的顺序是从上到下,渲染的顺序也是从上到下,下载和渲染是同时进行的.2.在渲染到页面的某一部分时,其上面的所有部分都已经下载完成(并不是说所有相关联的元素都 ...

  10. Android Studio 解决unspecified on project app resolves to an APK archive which is not supported

    出现该问题unspecified on project app resolves to an APK archive which is not supported as a compilation d ...