2015年第六届蓝桥杯C/C++程序设计本科B组决赛 完美正方形
完美正方形
如果一些边长互不相同的正方形,可以恰好拼出一个更大的正方形,则称其为完美正方形。历史上,人们花了很久才找到了若干完美正方形。比如:如下边长的22个正方形
2 3 4 6 7 8 12 13 14 15 16 17 18 21 22 23 24 26 27 28 50 60
如【图1.png】那样组合,就是一种解法。

此时,紧贴上边沿的是:60 50,紧贴下边沿的是:26 28 17 21 18
22阶完美正方形一共有8种。下面的组合是另一种:
2 5 9 11 16 17 19 21 22 24 26 30 31 33 35
36 41 46 47 50 52 61
如果告诉你该方案紧贴着上边沿的是从左到右依次为:47 46 61,你能计算出紧贴着下边沿的是哪几个正方形吗?
请提交紧贴着下边沿的正方形的边长,从左到右,用空格分开。
不要填写任何多余的内容或说明文字。
解题思路:
既然已经给出紧贴着上边沿的三个正方形,便可以得知最终拼接成的大正方形边长为47+46+61=154我们将整个大正方形视为一个154*154的地图,将47 46 61三个正方形先拼到地图顶端。之后找到第一个空闲位置,深搜填入其他正方形,直到找到可以填满地图的填充方式为止。
#include <bits/stdc++.h>
using namespace std;
const int EDGE = + + ;
//大正方形边长
int num[] = {, , , , , , , , , , , , , , , , , , };
//num需要是有序的
//记录剩下的所有可以被选取的正方形边长
int vis[] = {false};
//vis[i]记录i号正方形是否被选取过
int mp[EDGE][EDGE];
//地图
void fillUp(int x, int y, int length, int fillNumber){
//填充函数,x y为要填充位置的坐标(要填充正方形的左上角所在位置)
//length为填充正方形的长度,fillNumber表示填入地图的数字(填充时设为边长,拿出时设为0)
for(int i = x; i < x + length; i++)
for(int j = y; j < y + length; j++)
mp[i][j] = fillNumber;
}
bool isFull(){ //判断地图是否已被填满
for(int i = ; i < EDGE; i++)
for(int j = ; j < EDGE; j++)
if(!mp[i][j])
return false;
return true;
}
bool judge(int x, int y, int length){ //判断位置x y是否能填入边长为length的正方形
if(x + length > EDGE || y + length > EDGE)
return false;
for(int i = x; i < x + length; i++)
for(int j = y; j < y + length; j++)
if(mp[i][j])
return false;
return true;
}
bool dfs(int x, int y){
if(isFull()) //如果地图已被填满则找到答案,返回true
return true;
if(x > EDGE || y > EDGE)
return false;
bool flag = false;
int newX, newY;
for(int i = ; i < EDGE; i++){ //将newX newY记录为地图上第一个空位的坐标
for(int j = ; j < EDGE; j++)
if(!mp[i][j]){
newX = i, newY = j;
flag = true;
break;
}
if(flag)
break;
}
for(int i = ; i < ; i++){
if(judge(newX, newY, num[i])){ //位置newX newY能填入边长为num[i]的正方形 且边长为num[i]的正方形还没有被选取过
if(!vis[i]){
fillUp(newX, newY, num[i], num[i]); //将长度为num[i]的正方形 填入位置 newX, newY
vis[i] = true; //边长为num[i]的正方形标记为已选取
if(dfs(newX, newY + num[i]))
return true;
fillUp(newX, newY, num[i], ); //将长度为num[i]的正方形从位置 newX, newY取出
vis[i] = false; //边长为num[i]的正方形标记为未选取
}
}else //由于num是有序的只要num[i]无法放入位置newX newY则之后的正方形都无法放入位置newX newY
break;
}
return false;
}
int main()
{
fillUp(, , , );
fillUp(, , , );
fillUp(, , , );
//将题中给出的上方三个正方形填入地图
dfs(, );
//int ans = 0;
for(int j = ; j < EDGE; j++)
printf("%3d ", mp[][j]); //打印最后一行
return ;
}
答案:
50 33 30 41
2015年第六届蓝桥杯C/C++程序设计本科B组决赛 完美正方形的更多相关文章
- 2015年第六届蓝桥杯C/C++程序设计本科B组决赛
1.积分之谜(枚举) 2.完美正方形 3.关联账户(并查集) 4.密文搜索 5.居民集会 6.模型染色 1.积分之迷 小明开了个网上商店,卖风铃.共有3个品牌:A,B,C.为了促销,每件商品都会返固定 ...
- 2015年第六届蓝桥杯C/C++程序设计本科B组决赛 ——居民集会(编程大题)
标题:居民集会 蓝桥村的居民都生活在一条公路的边上,公路的长度为L,每户家庭的 位置都用这户家庭到公路的起点的距离来计算,第i户家庭距起点的距 离为di.每年,蓝桥村都要举行一次集会.今年,由于村里的 ...
- 2016年第六届蓝桥杯C/C++程序设计本科B组决赛 ——一步之遥(填空题题)
一步之遥 从昏迷中醒来,小明发现自己被关在X星球的废矿车里.矿车停在平直的废弃的轨道上.他的面前是两个按钮,分别写着“F”和“B”. 小明突然记起来,这两个按钮可以控制矿车在轨道上前进和后退.按F,会 ...
- 2016年第七届蓝桥杯C/C++程序设计本科B组决赛
2.答案300 刁丝卫代码,比赛时long long写成int,结果成了263...一等擦肩而过... #include <iostream> #include <fstream&g ...
- 第七届蓝桥杯C/C++程序设计本科B组决赛 ——机器人塔(程序大题)
机器人塔 X星球的机器人表演拉拉队有两种服装,A和B.他们这次表演的是搭机器人塔. 类似: A B B A B A A A B B B B B A BA B A B B A 队内的组塔规则是: A 只 ...
- 第七届蓝桥杯C/C++程序设计本科B组决赛 ——棋子换位(代码补全题)
棋子换位 有n个棋子A,n个棋子B,在棋盘上排成一行.它们中间隔着一个空位,用“.”表示,比如: AAA.BBB 现在需要所有的A棋子和B棋子交换位置.移动棋子的规则是:1. A棋子只能往右边移动,B ...
- 第七届蓝桥杯C/C++程序设计本科B组决赛 ——凑平方数(填空题)
凑平方数 把0~9这10个数字,分成多个组,每个组恰好是一个平方数,这是能够办到的.比如:0, 36, 5948721 再比如:10985247361, 25, 63907840, 4, 289, 1 ...
- 2016年第七届蓝桥杯C/C++程序设计本科B组省赛
/* 2016年第七届蓝桥杯C/C++程序设计本科B组省赛 煤球数目(结果填空) 煤球数目 有一堆煤球,堆成三角棱锥形.具体: 第一层放1个, 第二层3个(排列成三角形), 第三层6个(排列成三角形) ...
- 2015年第六届蓝桥杯国赛试题(JavaA组)
1.结果填空 (满分15分)2.结果填空 (满分35分)3.代码填空 (满分31分)4.程序设计(满分41分)5.程序设计(满分75分)6.程序设计(满分103分) 1.标题:胡同门牌号 小明家住在一 ...
随机推荐
- 【python-字典】判断python字典中key是否存在的
一般有两种通用做法: 第一种方法:使用自带函数实现: 在python的字典的属性方法里面有一个has_key()方法: #生成一个字典 d = {'name':Tom, 'age':10, 'Tel' ...
- Hdu2841 Visible Trees 2017-06-27 22:13 24人阅读 评论(0) 收藏
Visible Trees Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) To ...
- Codeforces816A Karen and Morning 2017-06-27 15:11 43人阅读 评论(0) 收藏
A. Karen and Morning time limit per test 2 seconds memory limit per test 512 megabytes input standar ...
- 基类的析构函数写成virtual虚析构函数
虚函数作用:动态绑定,实现多态效果. 场景问题: 派生类中有资源需要回收,而在编程中采用多态,由基类的指针指向派生类,则在释放的时候,如果基类的析构函数不是virtual,则派生类的析构函数得不到释放 ...
- shell wc -l
shell 命令之 wc -l 给出一个比较常用的命令: cat * | wc -l 查询当前文件夹下的文件的总行数. 原理就是统计了文件中换行符的数量.
- ubuntu16.04 LTS把下载源改为阿里云的源
为什么要切换下载源到国内的源上? Ubuntu的中国服务器下载速度很慢,我们可以尝试修改软件更新源,这样下载和更新软件的速度会加快很多. 一.linux系统版本: ubuntukylin-16.04- ...
- 探索基于.NET下实现一句话木马之asmx篇
0x01 前言 上篇介绍了一般处理程序(ashx)的工作原理以及实现一句话木马的过程,今天接着介绍Web Service程序 (asmx)下的工作原理和如何实现一句话木马,当然介绍之前笔者找到了一款a ...
- 【npm】详解npm的模块安装机制
依赖树表面的逻辑结构与依赖树真实的物理结构 依赖树表面的逻辑结构与依赖树真实的物理结构并不一定相同! 这里要先提到两个命令:tree -d(linux)和npm ls(npm) 在一个npm项目下 ...
- 关于SpringBoot开发微信模板推送
在这里演示一下微信的模板消息推送: 这里使用微信测试号 来演示: 先看下效果吧: 1.首先需要申请一个 微信测试号 https://mp.weixin.qq.com/wiki?t=resourc ...
- jQuery基础(3)- ajax
一.jQuery的ajax 1.什么是ajax AJAX = 异步的javascript和XML(Asynchronous Javascript and XML). 简言之,在不重载整个网页的情况下, ...