旅游的Final柱

题目连接:

http://acm.uestc.edu.cn/#/problem/show/1288

Description

柱神要去打Final啦(≧▽≦)/啦啦啦

柱神来到了异国他乡的普吉岛,柱神决定好好游览一番。

普吉岛的景点编号为11到NN,景点之间由双向的道路连接着,所有的道路的长度都是11。

柱神希望访问所有的景点,但是又不想耽搁太长的时间,所以柱神决定每天访问一个景点。

为了好好陶冶情操,柱神并不在路上花费太多的时间,所以柱神不会在连续的两天访问两个最短距离超过KK的景点。

由于柱神忙着打Final,所以旅行的方案就交个你了。

Input

第一行为两个整数N,KN,K,其中4<=N<=5004<=N<=500,3<=K<=N−13<=K<=N−1。

接下来NN行NN列,第ii行jj列的值aij=1aij=1或者aij=0aij=0。

如果aij=1aij=1,表示从景点ii到景点jj有一条长为11的道路,如果aij=0aij=0,则表示从ii到jj没有直接的道路。

图保证联通。

注意哦:数据以字符串的形式给出,只包含0和1,且aii=0

Output

输出一个11到NN的排列,第ii个数表示第ii天访问的景点编号。输出任意一组解即可。

Sample Input

4 3

0100

1010

0101

0010

Sample Output

1 3 2 4

Hint

题意

题解:

这道题给了你一个无向图,以及一个k,让你输出一个旅游方案,使得这个旅游方案恰好旅行每个点一次,且相邻的两个点之间的距离小于k。

这道题怎么做呢?

话音刚落,小郭同学发言了:“我觉得这个k的数据范围是500,我感觉瞎dfs一波或者bfs一波,再加点点随机化就好了。”

然后小郭同学非常开心的就去写了几发随机化,然后TLE,WA……

暴力显然是过不了了,那应该怎么做呢?

这是一道构造题,应该想想一些聪慧的办法。

这道题最困难的情况是什么呢?

答:他给你的那个无向图就是一颗树,且k就等于3。如果这个能够解决,那么显然原题目也就能解决啦。

这个怎么做呢?想啊想啊想啊。

想到了!

我们随便抓一个点,当做这个树的根,然后把这个点染成白色。然后剩下的点,与白点相连的点就染成黑色,与黑色相连的点就染成白色。

现在这棵树上的点,就只有黑点和白点了。

然后我们这样做:

定义函数dfs(x):

如果现在这个点是白点,那就输出这个点。

走向下一个与这个点相邻的点v,进行函数dfs(v)

如果现在这个点是黑点,那就输出这个点。

这样做之后,我们可以显然的发现,连续输出的两个点,如果都是黑色或者白色的话,距离等于2。连续输出的两个点是不同的颜色的话,距离为1或者3。

距离为3的情况是:

白4

|

黑3

|

白1--黑2

这样会输出1,2,4,3。

啦啦啦,显然这种构造方式,可以使得任意输出的连续两个点的距离小于等于3啦。

然后这道题就解决了~

代码

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int maxn = 505;
  4. string s;
  5. vector<int>E[maxn];
  6. int vis[maxn];
  7. void dfs(int x,int flag)
  8. {
  9. vis[x]=1;
  10. if(flag==0)printf("%d ",x);
  11. for(int i=0;i<E[x].size();i++)
  12. {
  13. if(vis[E[x][i]])continue;
  14. dfs(E[x][i],!flag);
  15. }
  16. if(flag==1)printf("%d ",x);
  17. }
  18. int main()
  19. {
  20. int n,k;
  21. scanf("%d%d",&n,&k);
  22. for(int i=1;i<=n;i++)
  23. {
  24. cin>>s;
  25. for(int j=0;j<s.size();j++)
  26. if(s[j]=='1')E[i].push_back(j+1);
  27. }
  28. dfs(1,0);
  29. }

CDOJ 1288 旅游的Final柱 构造题的更多相关文章

  1. cf251.2.C (构造题的技巧)

    C. Devu and Partitioning of the Array time limit per test 1 second memory limit per test 256 megabyt ...

  2. hdu4671 Backup Plan ——构造题

    link:http://acm.hdu.edu.cn/showproblem.php?pid=4671 其实是不难的那种构造题,先排第一列,第二列从后往前选. #include <iostrea ...

  3. Educational Codeforces Round 7 D. Optimal Number Permutation 构造题

    D. Optimal Number Permutation 题目连接: http://www.codeforces.com/contest/622/problem/D Description You ...

  4. Codeforces 482 - Diverse Permutation 构造题

    这是一道蛮基础的构造题. - k         +(k - 1)      -(k - 2) 1 + k ,    1 ,         k ,             2,    ....... ...

  5. BZOJ 3097: Hash Killer I【构造题,思维题】

    3097: Hash Killer I Time Limit: 5 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 963  Solved: 36 ...

  6. CF1110E Magic Stones(构造题)

    这场CF怎么这么多构造题…… 题目链接:CF原网 洛谷 题目大意:给定两个长度为 $n$ 的序列 $c$ 和 $t$.每次我们可以对 $c_i(2\le i<n)$ 进行一次操作,也就是把 $c ...

  7. CodeForces 297C Splitting the Uniqueness (脑补构造题)

    题意 Split a unique array into two almost unique arrays. unique arrays指数组各个数均不相同,almost unique arrays指 ...

  8. HDU 5355 Cake (WA后AC代码,具体解析,构造题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=5355 题面: Cake Time Limit: 2000/1000 MS (Java/Others) ...

  9. 【构造题 贪心】cf1041E. Tree Reconstruction

    比赛时候还是太慢了……要是能做快点就能上分了 Monocarp has drawn a tree (an undirected connected acyclic graph) and then ha ...

随机推荐

  1. 深入理解Spring系列之二:BeanDefinition解析

    转载 https://mp.weixin.qq.com/s?__biz=MzI0NjUxNTY5Nw==&mid=2247483814&idx=1&sn=ddf49931d55 ...

  2. MySQL Warning: Using a password on the command line interface can be insecure.解决办法

    转自 http://www.cnblogs.com/sunss/p/6256706.html  被一个小朋友问到,直接公布答案: If your MySQL client/server version ...

  3. apache 各种配置

    //apache 的网站配置文件 /usr/local/apache2/conf/extra/httpd-vhosts.conf -->在编辑这个文件前需要去httpd.conf把这个文件的注释 ...

  4. Nginx源码分析-ngx_module_s结构体

    该结构体是整个Nginx模块化架构最基本的数据结构体.它描述了Nginx程序中一个模块应该包括的基本属性,在tengine/src/core/ngx_conf_file.h中定义了该结构体 struc ...

  5. C#子线程中更新ui-----c# 多线程多文件批量下载

    c# 多线程多文件批量下载   废话少说,先演示一张效果图 简单说下过程喽 开发过程中其实总是会碰到项目想应用下载文件~ 看其他语言有很多封装好的类库可以使用~~ 作为小白的我并没有找到很多c#的案例 ...

  6. mysql视图学习总结(转)

    一.使用视图的理由是什么?1.安全性.一般是这样做的:创建一个视图,定义好该视图所操作的数据.之后将用户权限与视图绑定.这样的方式是使用到 了一个特性:grant语句可以针对视图进行授予权限.2.查询 ...

  7. error: expected expression before ‘struct

    Linux C/C++编程时常会遇到“error: expected expression before ‘struct’”错误,此错误一般是由未定义的宏(宏里套宏)或参量引起,导致编译器判断当前语句 ...

  8. CSS背景横向平铺BUG,解决方法

    给定DIV一个背景图片横向平铺,缩小浏览器,拉动横向滚动条,此时触发此BUG:背景图片平铺不完整 解决办法: 1.把背景图片写在BODY上,此办法局限于没有使用iframe的情况下,所以少用 2.设定 ...

  9. go-互斥锁及原子函数

    用于解决并发函数的竞争状态问题... package main import ( "fmt" "runtime" "sync" " ...

  10. GUC-2 原子性

    import java.util.concurrent.atomic.AtomicInteger; /* * 一.i++ 的原子性问题:i++ 的操作实际上分为三个步骤“读-改-写” * int i ...