平铺方案【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

相关文章

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig

在Java中将XLS转换为XLSX的实现方案

《在Java中将XLS转换为XLSX的实现方案》在本文中,我们将探讨传统ExcelXLS格式与现代XLSX格式的结构差异,并为Java开发者提供转换方案,通过了解底层原理、性能优势及实用工具,您将掌握... 目录为什么升级XLS到XLSX值得投入?实际转换过程解析推荐技术方案对比Apache POI实现编程

Java实现本地缓存的常用方案介绍

《Java实现本地缓存的常用方案介绍》本地缓存的代表技术主要有HashMap,GuavaCache,Caffeine和Encahche,这篇文章主要来和大家聊聊java利用这些技术分别实现本地缓存的方... 目录本地缓存实现方式HashMapConcurrentHashMapGuava CacheCaffe

无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案

《无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案》:本文主要介绍了无法启动此程序,详细内容请阅读本文,希望能对你有所帮助... 在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是"api-ms-win-core-path-l1-1-0.dll丢失

利用Python实现可回滚方案的示例代码

《利用Python实现可回滚方案的示例代码》很多项目翻车不是因为不会做,而是走错了方向却没法回头,技术选型失败的风险我们都清楚,但真正能提前规划“回滚方案”的人不多,本文从实际项目出发,教你如何用Py... 目录描述题解答案(核心思路)题解代码分析第一步:抽象缓存接口第二步:实现两个版本第三步:根据 Fea

SpringBoot实现接口数据加解密的三种实战方案

《SpringBoot实现接口数据加解密的三种实战方案》在金融支付、用户隐私信息传输等场景中,接口数据若以明文传输,极易被中间人攻击窃取,SpringBoot提供了多种优雅的加解密实现方案,本文将从原... 目录一、为什么需要接口数据加解密?二、核心加解密算法选择1. 对称加密(AES)2. 非对称加密(R