平铺方案【Ybtoj】

2024-01-30 07:38
文章标签 方案 ybtoj 平铺

本文主要是介绍平铺方案【Ybtoj】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

D e s c r i p t i o n Description Description

您可以通过几种方式用 2 ∗ 1 2*1 21 2 ∗ 2 2*2 22瓦片平铺 2 ∗ n 2*n 2n矩形?

这是一个 2 ∗ 17 2*17 217矩形的样本拼贴:

I n p u t Input Input

每行一个整数 n n n

O u t p u t Output Output

每行一个整数,表示方案数。

S a m p l e Sample Sample I n p u t Input Input
2
8
12
100
200
S a m p l e Sample Sample O u t p u t Output Output
3
171
2731
845100400152152934331135470251
1071292029505993517027974728227441735014801995855195223534251

H i n t Hint Hint

对于 100 % 100\% 100%的数据, 0 ≤ n ≤ 250 0 \leq n \leq 250 0n250

T r a i n Train Train o f of of T h o u g h t Thought Thought

F k F_k Fk表示有k列的方案数
那么可以考虑
1. F k − 1 1.F_{k-1} 1.Fk1中最后加一个 2 ∗ 1 2*1 21的方块
2. F k − 2 2.F_{k-2} 2.Fk2中最后加两个 1 ∗ 2 1*2 12的方块,或者一个 2 ∗ 2 2*2 22的方块
那么 F k = F k − 1 + F k − 2 ∗ 2 F_k=F_{k-1}+F_{k-2}*2 Fk=Fk1+Fk22
ps
高精压位

#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#define Mod 10000
#define ll long long
using namespace std;const int N = 500;ll A[300][N + 5];
ll n;void Add(int k)
{int g = 0;for(int i = 1; i <= N; ++i){A[k][i] = 2 * A[k - 2][i] + A[k - 1][i] + g;g = A[k][i] / Mod;A[k][i] %= Mod;}
}int main()
{A[1][1] = 1, A[2][1] = 3;for(int i = 3; i <= 250; ++i)Add(i);scanf("%lld", &n);while(n){int l = N + 1;while(--l && !A[n][l]);printf("%lld", A[n][l]);while(--l > 0){if(A[n][l] < 1000)printf("0");else if(A[n][l] < 100)printf("00");else if(A[n][l] < 10)printf("000");printf("%lld", A[n][l]);}printf("\n");n = 0;scanf("%lld", &n);}
}

这篇关于平铺方案【Ybtoj】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

MySQL容灾备份的实现方案

《MySQL容灾备份的实现方案》进行MySQL的容灾备份是确保数据安全和业务连续性的关键步骤,容灾备份可以分为本地备份和远程备份,主要包括逻辑备份和物理备份两种方式,下面就来具体介绍一下... 目录一、逻辑备份1. 使用mysqldump进行逻辑备份1.1 全库备份1.2 单库备份1.3 单表备份2. 恢复

redis中session会话共享的三种方案

《redis中session会话共享的三种方案》本文探讨了分布式系统中Session共享的三种解决方案,包括粘性会话、Session复制以及基于Redis的集中存储,具有一定的参考价值,感兴趣的可以了... 目录三种解决方案粘性会话(Sticky Sessions)Session复制Redis统一存储Spr

SpringBoot实现虚拟线程的方案

《SpringBoot实现虚拟线程的方案》Java19引入虚拟线程,本文就来介绍一下SpringBoot实现虚拟线程的方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录什么是虚拟线程虚拟线程和普通线程的区别SpringBoot使用虚拟线程配置@Async性能对比H

MySQL中读写分离方案对比分析与选型建议

《MySQL中读写分离方案对比分析与选型建议》MySQL读写分离是提升数据库可用性和性能的常见手段,本文将围绕现实生产环境中常见的几种读写分离模式进行系统对比,希望对大家有所帮助... 目录一、问题背景介绍二、多种解决方案对比2.1 原生mysql主从复制2.2 Proxy层中间件:ProxySQL2.3