2017 蓝桥杯决赛 C++B(2)瓷砖样式 dfs + hash去重

2024-04-05 23:48

本文主要是介绍2017 蓝桥杯决赛 C++B(2)瓷砖样式 dfs + hash去重,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

标题:磁砖样式

小明家的一面装饰墙原来是 3*10 的小方格。
现在手头有一批刚好能盖住2个小方格的长方形瓷砖。
瓷砖只有两种颜色:黄色和橙色。
小明想知道,对于这么简陋的原料,可以贴出多少种不同的花样来。
小明有个小小的强迫症:忍受不了任何2*2的小格子是同一种颜色。
(瓷砖不能切割,不能重叠,也不能只铺一部分。另外,只考虑组合图案,请忽略瓷砖的拼缝)
显然,对于 2*3 个小格子来说,口算都可以知道:一共10种贴法,如【p1.png所示】
但对于 3*10 的格子呢?肯定是个不小的数目,请你利用计算机的威力算出该数字。

注意:你需要提交的是一个整数,不要填写任何多余的内容(比如:说明性文字)


答案: 101466


#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<map>
using namespace std;int mp[4][11];
map<int,int> hash;
int tol;bool noSame()//判断是否存在4个方块同样 {for(int i = 1; i <= 2; ++i){for(int j = 1; j <= 9; ++j){if(mp[i][j] == mp[i+1][j] && mp[i+1][j] == mp[i][j+1] && mp[i][j+1] == mp[i+1][j+1])return false;}}return true;}void color(int x, int y, int type,int v)//根据type判断水平2块还是数值2块  染成 v {if(type == 1){ //水平 for(int i = x; i < x+1; ++i){for(int j = y; j < y+2; ++j){mp[i][j] = v;}}}else if(type == 2){for(int i = x; i < x+2; ++i){for(int j = y; j < y+1; ++j){mp[i][j] = v;}}}}
bool checkX(int x, int y)//判断X方向是否能放2块 {if(x+1 > 3 || y > 10)return false;for(int i = x; i < x+2; ++i){for(int j = y; j < y+1; ++j){if(mp[i][j])return false;}}return true;}void output(){for(int i = 1; i <= 3; ++i){for(int j = 1; j <= 10; ++j){printf("%d",mp[i][j]);}printf("\n");}}	bool checkY(int x, int y)//判断y方向能否放2块 {if(x > 3 || y+1 > 10)return false;for(int i = x; i < x+1; ++i){for(int j = y; j < y+2; ++j){if(mp[i][j])return false;}}	return true;}void dfs(int x, int y){if(x > 3){if(noSame()){int bit = 1;long long ans = 0;for(int i = 1; i <= 3; ++i){for(int j = 1; j <= 10; ++j){ans += bit*mp[i][j];//用ans来标识唯一的涂色方案bit <<= 1;}}if(!hash[ans]){++tol;++hash[ans];}}return ;}	if(mp[x][y] == 0){if(checkX(x,y)){for(int i = 1; i <= 2; ++i){//注意瓷砖有2种 可以染不同颜色 color(x,y,2,i);if(y == 10){dfs(x+1,1);}else{dfs(x,y+1);}color(x,y,2,0);}}if(checkY(x,y)){for(int i = 1; i <= 2; ++i){color(x,y,1,i);if(y == 10){dfs(x+1,1);}else{dfs(x,y+1);}color(x,y,1,0);}}}else{if(y == 10){dfs(x+1,1);}else{dfs(x,y+1);}}}int main(){memset(mp,0,sizeof(mp));dfs(1,1);printf("%d",tol);return 0;}

这篇关于2017 蓝桥杯决赛 C++B(2)瓷砖样式 dfs + hash去重的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/878486

相关文章

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

Python清空Word段落样式的三种方法

《Python清空Word段落样式的三种方法》:本文主要介绍如何用python-docx库清空Word段落样式,提供三种方法:设置为Normal样式、清除直接格式、创建新Normal样式,注意需重... 目录方法一:直接设置段落样式为"Normal"方法二:清除所有直接格式设置方法三:创建新的Normal样

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3