洛谷P1228 地毯填补问题
P1228 地毯填补问题
题目描述
相传在一个古老的阿拉伯国家里,有一座宫殿。宫殿里有个四四方方的格子迷宫,国王选择驸马的方法非常特殊,也非常简单:公主就站在其中一个方格子上,只要谁能用地毯将除公主站立的地方外的所有地方盖上,美丽漂亮聪慧的公主就是他的人了。公主这一个方格不能用地毯盖住,毯子的形状有所规定,只能有四种选择(如图4-l):

并且每一方格只能用一层地毯,迷宫的大小为(2k)^2的方形。当然,也不能让公主无限制的在那儿等,对吧?由于你使用的是计算机,所以实现时间为1s。
输入输出格式
输入格式:
输入文件共2行。
第一行:k,即给定被填补迷宫的大小为2^k(0<k≤10);
第二行:x y,即给出公主所在方格的坐标(x为行坐标,y为列坐标),x和y之间有一个空格隔开。
输出格式:
将迷宫填补完整的方案:每一补(行)为x y c (x,y为毯子拐角的行坐标和列坐标,c为使用毯子的形状,具体见上面的图1,毯子形状分别用1、2、3、4表示,x、y、c之间用一个空格隔开)。
输入输出样例
3
3 3
5 5 1
2 2 4
1 1 4
1 4 3
4 1 2
4 4 1
2 7 3
1 5 4
1 8 3
3 6 3
4 8 1
7 2 2
5 1 4
6 3 2
8 1 2
8 4 1
7 7 1
6 6 1
5 8 3
8 5 2
8 8 1
/*
分治思想:每一次都可以通过将棋盘切成四块缩小规模,直到缩小到规模为1*1时,结束递归。
每次覆盖都是将牌放在当前棋盘中间,分成四个部分,肯定只有三个部分包含一个三分之一牌(一个黑块),于是每一部分都成了只有一个黑牌的子问题。
由于题目没有描述输出的次序,要注意顺序默认为左上,右上,左下,右下。
*/
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
#define maxn 1<<11
int X,Y,C,map[maxn][maxn];
int check(int x1,int y1,int x2,int y2){
int x=(x1+x2)/;
int y=(y1+y2)/;
for(int i=x1;i<=x2;i++)
for(int j=y1;j<=y2;j++)
if(map[i][j]){
if(i<=x){
if(j<=y)return ;
else return ;
}
else{
if(j<=y)return ;
return ;
}
}
}
void dfs(int x1,int y1,int x2,int y2){
int x=(x1+x2)/+;
int y=(y1+y2)/+;
int ans=check(x1,y1,x2,y2);
if(ans==){
printf("%d %d %d\n",x,y,ans);
map[x][y]=;
map[x][y-]=;
map[x-][y]=;
}
if(ans==){
printf("%d %d %d\n",x,y-,ans);
map[x][y-]=;
map[x-][y-]=;
map[x][y]=;
}
if(ans==){
printf("%d %d %d\n",x-,y,ans);
map[x][y]=;
map[x-][y]=;
map[x-][y-]=;
}
if(ans==){
printf("%d %d %d\n",x-,y-,ans);
map[x-][y]=;
map[x-][y-]=;
map[x][y-]=;
}
if(x2-x1>=){
dfs(x1,y1,x-,y-);
dfs(x1,y,x-,y2);
dfs(x,y1,x2,y-);
dfs(x,y,x2,y2);
}
}
int main(){
scanf("%d%d%d",&C,&X,&Y);
map[X][Y]=;
dfs(,,<<C,<<C);
}
洛谷P1228 地毯填补问题的更多相关文章
- 浅谈分治 —— 洛谷P1228 地毯填补问题 题解
		
如果想看原题网址的话请点击这里:地毯填补问题 原题: 题目描述 相传在一个古老的阿拉伯国家里,有一座宫殿.宫殿里有个四四方方的格子迷宫,国王选择驸马的方法非常特殊,也非常简单:公主就站在其中一个方格子 ...
 - [洛谷P1228]地毯填补问题 题解(分治)
		
Description 相传在一个古老的阿拉伯国家里,有一座宫殿.宫殿里有个四四方方的格子迷宫,国王选择驸马的方法非常特殊,也非常简单:公主就站在其中一个方格子上,只要谁能用地毯将除公主站立的地方外的 ...
 - P1228 地毯填补问题(分治)
		
P1228 地毯填补问题(分治) 题目描述 相传在一个古老的阿拉伯国家里,有一座宫殿.宫殿里有个四四方方的格子迷宫,国王选择驸马的方法非常特殊,也非常简单:公主就站在其中一个方格子上,只要谁能用地毯将 ...
 - 洛谷 P1228 【地毯填补问题】
		
事实上感觉四个的形状分别是这样: spj报错: 1:c 越界 2:x,y 越界 3:mp[x][y] 已被占用 4:mp[x][y] 从未被使用 题解: 初看这个问题,似乎无从下手,于是我们可以先考虑 ...
 - 洛谷 P3397 地毯
		
P3397 地毯 题目背景 此题约为NOIP提高组Day2T1难度. 题目描述 在n*n的格子上有m个地毯. 给出这些地毯的信息,问每个点被多少个地毯覆盖. 输入输出格式 输入格式: 第一行,两个正整 ...
 - 洛谷P1228 分治
		
https://www.luogu.org/problemnew/show/P1228 我真傻,真的,我单知道这种题目可以用dfs剪枝过,没有想到还能构造分治,当我敲了一发dfs上去的时候,只看到一个 ...
 - 洛谷  P3397 地毯 【二维差分标记】
		
题目背景 此题约为NOIP提高组Day2T1难度. 题目描述 在n*n的格子上有m个地毯. 给出这些地毯的信息,问每个点被多少个地毯覆盖. 输入输出格式 输入格式: 第一行,两个正整数n.m.意义如题 ...
 - 洛谷-铺地毯-NOIP2011提高组复赛
		
题目描述 为了准备一个独特的颁奖典礼,组织者在会场的一片矩形区域(可看做是平面直角坐标系的第一象限)铺上一些矩形地毯.一共有 n 张地毯,编号从 1 到n .现在将这些地毯按照编号从小到大的顺序平行于 ...
 - 洛谷P3397 地毯(差分)
		
二维平面上的差分,我们可以对每行处理. 比如我们要把(2,2)(5,5)之间的矩形加上1,可以这样处理. 0 0 0 0 0 0 0 +1 0 0 0 -1 0 +1 0 0 0 -1 0 +1 0 ...
 
随机推荐
- python之学习
			
------------------------------------------ 基本语句解析 import:导入某些模块或者文件 import random: 导入生成随机数模块 import ...
 - Chart.js 动态图表的使用
			
一.相关资料 1. 简介 Chart.js 是一个基于 HTML5 的简单的面向对象的图表库,支持包括 IE7/8 和所有现代浏览器.支持六种图标:曲线图(Linecharts).柱状图(Barcha ...
 - Contiki 2.7 Makefile 文件(三)
			
2.第二部分 这里的usage,targets,savetarget,savedefines都是伪目标. 和all不同,这些伪目标不会被执行,除非显式指定这些目标. 这里有两个目标savetarget ...
 - POJ 2096 Collecting Bugs:期望dp
			
题目链接:http://poj.org/problem?id=2096 题意: 有一个程序猿,他每天都会发现一个bug. bug共有n个种类.属于某一个种类的概率为1/n. 有s个子系统,每个bug属 ...
 - html5--1.15 style元素与HTML样式基础
			
html5--1.15 style元素与HTML样式基础 学习要点: 1.引入样式的三种方式2.了解style元素插入内联样式表与内部样式表 1.引入样式的三种方式 1.外部样式表:通过 link元素 ...
 - JQuery调用iframe子页面函数/对象的方法
			
父页面有个ID为mainfrm的iframe,iframe连接b.html,该页面有个函数test 在父页面调用b.html的test方法为: $("#mainfrm")[0].c ...
 - 安装.NET Core 3.0预览版后VS项目目标框架中不显示的解决方法
			
下载了微软在GitHub上的cSharpSamples项目后发现其中一些项目使用框架为.NET Core3.0,就下载了.NET Core3.0,但发现项目依然不可用,编译时提示如下 当前 .net ...
 - super.onCreate(savedInstanceState) 以及onCreate(Bundle savedInstanceState, PersistableBundle persistentState)
			
super.onCreate(savedInstanceState) 调用父类的onCreate构造函数. 当一个Activity在生命周期结束前,会调用onSaveInsanceState()这个回 ...
 - 发挥到极致的Asterisk SS7 解决方案【转】
			
基于SS7的开源解决方案在国内已经安装了很多.很多用户都使用chan_ss7 开源协议栈作为呼叫中心,400电话,计费结算的系统.随着国内对开源Asterisk的认可程度越来越高. Asterisk让 ...
 - 谈"零缺陷"
			
在刚参加工作初期的一次关于质量的培训中,第一次听到"零缺陷"这个词懵懵懂懂,当成一道概念题给记下.今年重读<质量免费>时对与零缺陷的部分始终心存疑虑,最近读<第一 ...