2663 Tri Tiling 完美覆盖,样例分析+详细题解-只需10行代码

2023-10-24 14:10

本文主要是介绍2663 Tri Tiling 完美覆盖,样例分析+详细题解-只需10行代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

描述

一张普通的国际象棋棋盘,它被分成 8 乘 8 (8 行 8 列) 的 64 个方格。设有形状一样的多米诺牌,每张牌恰好覆盖棋盘上相邻的两个方格,即一张多米诺牌是一张 1 行 2 列或者 2 行 1 列的牌。那么,是否能够把 32 张多米诺牌摆放到棋盘上,使得任何两张多米诺牌均不重叠,每张多米诺牌覆盖两个方格,并且棋盘上所有的方格都被覆盖住?我们把这样一种排列称为棋盘被多米诺牌完美覆盖。这是一个简单的排列问题,同学们能够很快构造出许多不同的完美覆盖。但是,计算不同的完美覆盖的总数就不是一件容易的事情了。不过,同学们 发挥自己的聪明才智,还是有可能做到的。
现在我们通过计算机编程对 3 乘 n 棋盘的不同的完美覆盖的总数进行计算。
在这里插入图片描述
任务
对 3 乘 n 棋盘的不同的完美覆盖的总数进行计算。

输入

一次输入可能包含多行,每一行分别给出不同的 n 值 ( 即 3 乘 n 棋盘的列数 )。当输入 -1 的时候结束。

n 的值最大不超过 30.

输出

针对每一行的 n 值,输出 3 乘 n 棋盘的不同的完美覆盖的总数。

思路

看着有点麻烦,其实不难,代码10行就够了。
首先对 n = 2 n=2 n=2时,对3*2的棋盘我们有三种(丑,勿怪)覆盖方式
在这里插入图片描述
对样例来说有12行,我们挑几种形式来分析一下
在这里插入图片描述

  • n n n是奇数,可以考虑一列,三列,5列的情形,你会发现,只要是奇数列,我们完全没有办法把他填充完整,因此我们可以考虑以两列为一个单位。
  • 记函数 f ( n ) f(n) f(n)为在 n n n列时的覆盖方案数目, f ( 0 ) = 1 f(0)=1 f(0)=1,为什么这么初始化?看 f ( 2 ) f(2) f(2)我们以两列为一个单位,那么他必定与 f ( 0 ) f(0) f(0)的排列总数有关,而 f ( 2 ) = 3 f(2)=3 f(2)=3是0号位置的排列数目之和*[1-2]位置的排列方法数目,因此初始化为1.
  • 再来看看 f ( 4 ) f(4) f(4),也就是下图红线框起来的部分。首先考虑他最右边两列有三种情况,承上之前的排列数即 f ( 2 ) ∗ 3 f(2)*3 f(2)3,不止如此,他的四列也可能长蓝线框起来这样,这种情况下有几种组合呢,答案是 f ( 0 ) ∗ 2 f(0)*2 f(0)2
    在这里插入图片描述
  • 最后我们看看 f ( n ) f(n) f(n),首先他的最后两列有三种情况 f ( n ) = 3 ∗ f ( n − 2 ) + . . . f(n)=3*f(n-2)+... f(n)=3f(n2)+...,然后他的最后四列单独拿出来有两种情况 f ( n ) = 3 ∗ f ( n − 2 ) + 2 ∗ f ( n − 4 ) + . . . f(n)=3*f(n-2)+2*f(n-4)+... f(n)=3f(n2)+2f(n4)+...,他的最后六列单独拿出来也只有两种情况:于是 f ( n ) = 3 ∗ f ( n − 2 ) + 2 ∗ f ( n − 4 ) + 2 ∗ f ( n − 6 ) + . . . f(n)=3*f(n-2)+2*f(n-4)+2*f(n-6)+... f(n)=3f(n2)+2f(n4)+2f(n6)+...,不断的向前递归我们得到
    在这里插入图片描述
    f ( n ) = 3 ∗ f ( n − 2 ) + 2 ∗ f ( n − 4 ) + 2 ∗ f ( n − 6 ) + . . . + 2 ∗ f ( 0 ) f(n)=3*f(n-2)+2*f(n-4)+2*f(n-6)+...+2*f(0) f(n)=3f(n2)+2f(n4)+2f(n6)+...+2f(0)
    f ( n − 2 ) = 3 ∗ f ( n − 4 ) + 2 ∗ f ( n − 6 ) + . . . + 2 ∗ f ( 0 ) ) f(n-2)=3*f(n-4)+2*f(n-6)+...+2*f(0)) f(n2)=3f(n4)+2f(n6)+...+2f(0))
    f ( n ) = 4 f ( n − 2 ) − f ( n − 4 ) f(n)=4f(n-2)-f(n-4) f(n)=4f(n2)f(n4)
#include<iostream>
using namespace std;
int f[35];
int main() {int n = 0; f[0] = 1, f[2] = 3;for (int i = 4; i < 35; i++)f[i] = 4 * f[i - 2] - f[i - 4];while (cin >> n && n != -1) {cout << f[n] << endl;}
}

这篇关于2663 Tri Tiling 完美覆盖,样例分析+详细题解-只需10行代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/csyifanZhang/article/details/104964521
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/275719

相关文章

IIS 7.0 及更高版本中的 FTP 状态代码

《IIS7.0及更高版本中的FTP状态代码》本文介绍IIS7.0中的FTP状态代码,方便大家在使用iis中发现ftp的问题... 简介尝试使用 FTP 访问运行 Internet Information Services (IIS) 7.0 或更高版本的服务器上的内容时,IIS 将返回指示响应状态的数字代

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

MySQL 添加索引5种方式示例详解(实用sql代码)

《MySQL添加索引5种方式示例详解(实用sql代码)》在MySQL数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中,下面给大家分享MySQL添加索引5种方式示例详解(实用sql代码),... 在mysql数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中。索引可以在创建表时定义,也可

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元

Python实现一键PDF转Word(附完整代码及详细步骤)

《Python实现一键PDF转Word(附完整代码及详细步骤)》pdf2docx是一个基于Python的第三方库,专门用于将PDF文件转换为可编辑的Word文档,下面我们就来看看如何通过pdf2doc... 目录引言:为什么需要PDF转Word一、pdf2docx介绍1. pdf2docx 是什么2. by

Linux中的more 和 less区别对比分析

《Linux中的more和less区别对比分析》在Linux/Unix系统中,more和less都是用于分页查看文本文件的命令,但less是more的增强版,功能更强大,:本文主要介绍Linu... 目录1. 基础功能对比2. 常用操作对比less 的操作3. 实际使用示例4. 为什么推荐 less?5.

spring-gateway filters添加自定义过滤器实现流程分析(可插拔)

《spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔)》:本文主要介绍spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔),本文通过实例图... 目录需求背景需求拆解设计流程及作用域逻辑处理代码逻辑需求背景公司要求,通过公司网络代理访问的请求需要做请

Spring Security介绍及配置实现代码

《SpringSecurity介绍及配置实现代码》SpringSecurity是一个功能强大的Java安全框架,它提供了全面的安全认证(Authentication)和授权(Authorizatio... 目录简介Spring Security配置配置实现代码简介Spring Security是一个功能强

通过cmd获取网卡速率的代码

《通过cmd获取网卡速率的代码》今天从群里看到通过bat获取网卡速率两段代码,感觉还不错,学习bat的朋友可以参考一下... 1、本机有线网卡支持的最高速度:%v%@echo off & setlocal enabledelayedexpansionecho 代码开始echo 65001编码获取: >

Java集成Onlyoffice的示例代码及场景分析

《Java集成Onlyoffice的示例代码及场景分析》:本文主要介绍Java集成Onlyoffice的示例代码及场景分析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 需求场景:实现文档的在线编辑,团队协作总结:两个接口 + 前端页面 + 配置项接口1:一个接口,将o