CDOJ 1288 旅游的Final柱 构造题
旅游的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啦。
然后这道题就解决了~
代码
#include<bits/stdc++.h>
using namespace std;
const int maxn = 505;
string s;
vector<int>E[maxn];
int vis[maxn];
void dfs(int x,int flag)
{
vis[x]=1;
if(flag==0)printf("%d ",x);
for(int i=0;i<E[x].size();i++)
{
if(vis[E[x][i]])continue;
dfs(E[x][i],!flag);
}
if(flag==1)printf("%d ",x);
}
int main()
{
int n,k;
scanf("%d%d",&n,&k);
for(int i=1;i<=n;i++)
{
cin>>s;
for(int j=0;j<s.size();j++)
if(s[j]=='1')E[i].push_back(j+1);
}
dfs(1,0);
}
CDOJ 1288 旅游的Final柱 构造题的更多相关文章
- cf251.2.C (构造题的技巧)
C. Devu and Partitioning of the Array time limit per test 1 second memory limit per test 256 megabyt ...
- hdu4671 Backup Plan ——构造题
link:http://acm.hdu.edu.cn/showproblem.php?pid=4671 其实是不难的那种构造题,先排第一列,第二列从后往前选. #include <iostrea ...
- Educational Codeforces Round 7 D. Optimal Number Permutation 构造题
D. Optimal Number Permutation 题目连接: http://www.codeforces.com/contest/622/problem/D Description You ...
- Codeforces 482 - Diverse Permutation 构造题
这是一道蛮基础的构造题. - k +(k - 1) -(k - 2) 1 + k , 1 , k , 2, ....... ...
- BZOJ 3097: Hash Killer I【构造题,思维题】
3097: Hash Killer I Time Limit: 5 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 963 Solved: 36 ...
- CF1110E Magic Stones(构造题)
这场CF怎么这么多构造题…… 题目链接:CF原网 洛谷 题目大意:给定两个长度为 $n$ 的序列 $c$ 和 $t$.每次我们可以对 $c_i(2\le i<n)$ 进行一次操作,也就是把 $c ...
- CodeForces 297C Splitting the Uniqueness (脑补构造题)
题意 Split a unique array into two almost unique arrays. unique arrays指数组各个数均不相同,almost unique arrays指 ...
- HDU 5355 Cake (WA后AC代码,具体解析,构造题)
题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=5355 题面: Cake Time Limit: 2000/1000 MS (Java/Others) ...
- 【构造题 贪心】cf1041E. Tree Reconstruction
比赛时候还是太慢了……要是能做快点就能上分了 Monocarp has drawn a tree (an undirected connected acyclic graph) and then ha ...
随机推荐
- webgote的例子 数据库与sql注入的相关联系(1)
大家好我是时光凉春衫薄 之前将讲的sql注入有点随便了我同事也觉得有些地方看不懂,往后的几天我尽量写的细一点.尽可能让大家能看懂.(新手出道大佬多多指教.欢迎评论批评.) 数据库与sql注入的相关联系 ...
- 最小的Django应用
创建一个hello.py 内容如下: import sys from django.conf import settings # 设置 settings.configure( DEBUG = Tr ...
- [ python ] 字典的使用
数据类型划分: 可变数据类型:list.dict.set 不可哈希 不可变数据类型:tuple.bool.int.str 可哈希 字典 python内置了字典类型,使用键-值( ...
- H5移动端视频问题(苹果全屏播放问题等)
iphone上,手动.自动.窗口化等问题 iphone窗口化 解决方案: 通过canvas + video标签结合处理 原理: 获取video的原图帧,通过canavs绘制到页面. 我们一般在苹果上在 ...
- 转:在CentOS 7.3使用yum安装 MySql5.6.24
按照CentOS 6.5的方法在CentOS 7上安装会失败,需要按照下文进行安装. 1.安装rpm包 Linux系统自带的repo是不会自动更新每个软件的最新版本(基本都是比较靠后的稳定版),所以无 ...
- 关闭windows 7的自动休眠功能
powercfg -h off powercfg -h on https://www.tulaoshi.com/n/20160401/2075397.html powercfg -h on 该文章&l ...
- 重记解决kube-dns故障一则---ceph惹的祸
上次,在同一个k8s集群里安装完ceph进行功能测试. 当测试完成之后,我停止了ceph的程序,再重新启动k8s集群. 结果,有一个应用就出问题了. 后来查出是因为防火墙里 Chain FORWARD ...
- <<Javascript Patterns>>阅读笔记 -- 第2章 基本技巧(一)
第一次写这种东西, 有些生涩和蹩脚, 也是为了自己在表达或是总结方面有所提高, 同时为看过的东西留个痕迹, 以便日后查阅. 有错误或是不妥的地方, 还望各位指正, 谢谢! 第1章 简介 本章主要介绍了 ...
- js红包算法【转载】
源文地址:https://juejin.im/post/5ae413946fb9a07a9c03f7f7 <!DOCTYPE html> <html lang="en&qu ...
- html5弹性布局两则,有交互。
要开发一个后台管理框架,要求如下效果. 然后开始找各种弹性布局啊什么的,用了flex写了一个,但是觉得不好,首先是兼容,其次它会破坏掉里面子元素的一些css特性,为了不给自己找麻烦我还是用传统写法吧. ...