历届试题 格子刷油漆

时间限制:1.0s   内存限制:256.0MB

问题描述

  X国的一段古城墙的顶端可以看成 2*N个格子组成的矩形(如下图所示),现需要把这些格子刷上保护漆。


  你可以从任意一个格子刷起,刷完一格,可以移动到和它相邻的格子(对角相邻也算数),但不能移动到较远的格子(因为油漆未干不能踩!)
  比如:a d b c e f 就是合格的刷漆顺序。
  c e f d a b 是另一种合适的方案。
  当已知 N 时,求总的方案数。当N较大时,结果会迅速增大,请把结果对 1000000007 (十亿零七) 取模。

输入格式

  输入数据为一个正整数(不大于1000)

输出格式

  输出数据为一个正整数。

样例输入

2

样例输出

24

样例输入

3

样例输出

96

样例输入

22

样例输出

359635897

dp题细节弄好就AC(瞎模拟 瞎推就完事了。。)

思路:

首先出发点不同是不同的情况,那么所有情况的和就是结果。

如图(从x开始,先刷x和y的左边,包括x,和y)

假设有上述情况,先从x刷,假设先从x出发刷x和y的左边,那么一定会回到y,再从y出发,刷x和y的右边。(可以模拟出来这个结论)。

从x出发先刷x和y的右边同理,所以答案是先左或先右相加。

所以要记录2*N大小的格子从边缘一点开始遍历整个格子并返回同一列的情况数backdp[ ],

和2*N大小的格子从边缘一点开始遍历整个格子不一定要返回同一列的情况数unbackdp[ ]。

假设有了上述条件之后,如图

因为回到y可以向红色箭头两个方向走,所以答案数*2。

当x处于第i列,第1行和第2行是等效的,所以答案数*。

所以当x处于第i列的时候,x的方案数为re=(backdp[i]*unbackdp[n-i]*2+backdp[n-i+1]*unbackdp[i-1]*2)*2。

#include <bits/stdc++.h>
using namespace std;
#define LL long long
#define mod 1000000007
#define MAXN 1000000007
#define pai acos(-1)
#define FOR(a,b) for(int i=a;i<=b;i++)
LL backdp[1005];
LL unbackdp[1005];
int main()
{int n;cin>>n;if(n==1){cout<<2;return 0;}//注意边界backdp[1]=1;FOR(2,1000){backdp[i]=backdp[i-1]*2%mod;}unbackdp[1]=1;unbackdp[2]=6;FOR(3,1000){unbackdp[i]=unbackdp[i-1]*2%mod;unbackdp[i]=(unbackdp[i]+unbackdp[i-2]*2%mod)%mod;unbackdp[i]=(unbackdp[i]+unbackdp[i-2]*2%mod)%mod;unbackdp[i]=(unbackdp[i]+backdp[i-1])%mod;unbackdp[i]=(unbackdp[i]+backdp[i-1])%mod;}LL re=unbackdp[n]*4%mod;//注意边界FOR(2,n-1){LL x=backdp[i]*unbackdp[n-i]*2%mod;//先处理左x=(x+backdp[n-i+1]*unbackdp[i-1]*2%mod)%mod;//右x=x*2%mod;re=(re+x)%mod;}cout<<re;return 0;
}

蓝桥 历届试题 格子刷油漆相关推荐

  1. 【蓝桥杯】历届试题 格子刷油漆(动态规划)

    历届试题 格子刷油漆 问题描述 X国的一段古城墙的顶端可以看成 2×N个格子组成的矩形(如下图所示),现需要把这些格子刷上保护漆. 例如下图是一个长度为3,高为2的城墙 你可以从任意一个格子刷起,刷完 ...

  2. 历届试题 格子刷油漆

    历届试题 格子刷油漆   问题描述 X国的一段古城墙的顶端可以看成 2*N个格子组成的矩形(如下图所示),现需要把这些格子刷上保护漆. 你可以从任意一个格子刷起,刷完一格,可以移动到和它相邻的格子(对 ...

  3. Java刷漆问题代码_Java实现蓝桥杯历届试题格子刷油漆

    问题描述 X国的一段古城墙的顶端可以看成 2*N个格子组成的矩形(如下图所示),现需要把这些格子刷上保护漆. 你可以从任意一个格子刷起,刷完一格,可以移动到和它相邻的格子(对角相邻也算数),但不能移动 ...

  4. 蓝桥杯 历届试题 格子刷油漆

    问题描述 X国的一段古城墙的顶端可以看成 2*N个格子组成的矩形(如下图所示),现需要把这些格子刷上保护漆. 你可以从任意一个格子刷起,刷完一格,可以移动到和它相邻的格子(对角相邻也算数),但不能移动 ...

  5. 动态规划 之 历届试题 格子刷油漆

    问题场景: X国的一段古城墙的顶端可以看成 2*N个格子组成的矩形(如下图所示),现需要把这些格子刷上保护漆. 你可以从任意一个格子刷起,刷完一格,可以移动到和它相邻的格子(对角相邻也算数),但不能移 ...

  6. 蓝桥杯历届试题 格子刷油漆

    如果可以,可以陪你千年不老,千年只想眷顾你倾城一笑;如果愿意,愿意陪你永世不离,永世只愿留恋你青丝白衣. #include <iostream> #include <cstdio&g ...

  7. java蓝桥杯练习 格子刷油漆

    java蓝桥杯练习 格子刷油漆 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 X国的一段古城墙的顶端可以看成 2*N个格子组成的矩形(如下图所示),现需要把这些格子刷上保护漆. 你 ...

  8. 蓝桥杯 PREV-15 格子刷油漆

    历年试题 PREV-15 格子刷油漆 题目:传送门 解析: 分析题目我们可以知道刷油漆的的起点可以分为两类,一是在第一列和最后一列的四个格子开始:而是在中间的某个格子开始. 对于从角落开始的方案比较好 ...

  9. 【蓝桥杯】格子刷油漆

    问题描述 X国的一段古城墙的顶端可以看成 2*N个格子组成的矩形(如下图所示),现需要把这些格子刷上保护漆. 你可以从任意一个格子刷起,刷完一格,可以移动到和它相邻的格子(对角相邻也算数),但不能移动 ...

最新文章

  1. python是c语言写的吗-python是c语言开发的吗
  2. Swift中的集合类之数组
  3. 微软一站式示例代码库 2012 年2月示例代码更新。8个全新示例为您的开发保驾护航...
  4. Linux上搭建h2引擎加载h2文件
  5. linux逻辑分区最小值,linux 逻辑卷管理 调整分区大小
  6. 伯努利数(详解 + 例题 :P3711 仓鼠的数学题)
  7. python中斐波那契数列_斐波那契数列–在Python,JavaScript,C ++,Java和Swift中进行了解释...
  8. 360极速模式和兼容模式对页面的影响
  9. 【笔记】具有O-DU和O-RU的eNB / gNB架构
  10. mysql删除表单挑数据_MySQL 删除数据表
  11. webmail lite php,自建webmail网页客户端
  12. Rust 1.34.1 稳定版发布,Bug 修复
  13. python是一种编译语言_解释型语言和编译型语言的不同以及Python如何运行
  14. 强制 Google.com 域名使用 HTTPS(SSL)
  15. DevExpress DateEdit控件选择精确到秒
  16. 兄弟dcp9020cdn手册_兄弟Brother DCP-9020CDN 驱动
  17. 浮动定位弹性页面的布局。
  18. 四柱排盘系统--阳历转农历
  19. mybatisplus删除操作引起的selectBatchIds报错
  20. 【BZOJ1921】【CTSC2010】珠宝商(点分治,后缀自动机)

热门文章

  1. iphone android 安兔兔,iPhone XR安兔兔跑分曝光,性能碾压一切Android手机
  2. windows xp常识(很有用的而且很常用的)
  3. 手机丅f丅lcd什么屏_iPhone7 Plus的屏幕怎么样?屏幕材质是什么?
  4. 高级Java工程师高频面试题总结
  5. [转贴]同济大学软件学院万院长谈择业
  6. pca 累积方差贡献率公式_PCA的原理及详细步骤
  7. ajax的jsonp原理,jsonp 跨域原理和用法(上篇)
  8. 九九减法.加法.除法表大全
  9. 暗夜精灵5 i7-9750H 1660ti 如何开启键盘背光?
  10. 用树莓派4b构建深度学习应用(十四)素描线稿篇