很久没有做题了,前天做了一道题结果弱的一逼。。。搜了解题报告不说...还尼玛秀了上限

题意:

给出宽和高为n和m的一堵墙,手上有长为1,2,3,4高均为1的砖,问形成一个坚固的墙有多少种做法。

坚固的意思是,不能一刀切到底。

解法:

将问题进行分解。求的所有坚固的墙ans(w,h)=所有墙all(w,h)-所有不坚固的墙bro(w,h)

所有的墙all(w,h)=一层的所有情况x(w)**h

所有不坚固的墙bro(w,h) = ans(1,h)*all(w-1,h)+ans(2,h)*all(w-2,h)+...+ans(w-1,h)*all(1,h)

x(w,1) = x(w-1,1)+x(w-2,1)+x(w-3,1)+x(w-4,1)

显然剩下的就是dp了

细节:

因为取余数,做减法的时候,有可能会发生不够减的情况记得+R就好

自己犯的错误:

这题的范围是t <=100 n,m<=1000

如果对于每个case都进行dp的话,是n*n*t的复杂度

然后如果进行预处理的话是n*n*n

然后问题就出在这里了 预处理的话会TLE

但是有个cheat的办法就是输入之后先判断下每个高度最大的w就能过。

 #include <cmath>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
#include <cstring> using namespace std; const int MAXSIZE = ;
const int R = ;
int wall[MAXSIZE][MAXSIZE];
int ans[MAXSIZE][MAXSIZE];
int vw[MAXSIZE];
int vh[MAXSIZE];
int hm[MAXSIZE];
int t;
int wmax;
int hmax; void input(){
cin>>t;
for ( int i = ; i < t; i++ ) {
cin>>vh[i]>>vw[i];
wmax = wmax<vw[i] ? vw[i]:wmax;
hmax = hmax>vh[i] ? hmax:vh[i];
}
for ( int i = ; i < t; i++ ) {
hm[vh[i]] = hm[vh[i]]>vw[i] ? hm[vh[i]]:vw[i];
}
} void init() {
memset(wall,,sizeof(wall));
memset(ans,,sizeof(ans));
wall[][] = ;
wall[][] = ;
wall[][] = ;
wall[][] = ;
ans[][] = ;
ans[][] = ;
ans[][] = ;
ans[][] = ;
for ( int w = ; w <= wmax; w++ ) {
wall[w][] = (wall[w][] + wall[w-][]%R)%R;
wall[w][] = (wall[w][] + wall[w-][]%R)%R;
wall[w][] = (wall[w][] + wall[w-][]%R)%R;
wall[w][] = (wall[w][] + wall[w-][]%R)%R;
}
for ( int h = ; h <= hmax; h++ ) {
wall[][h] = ;
ans[][h] = ;
}
for ( int w = ; w <= wmax; w++ ) {
for ( int h = ; h <= hmax; h++ ) {
wall[w][h] = ((long long)wall[w][h-]*wall[w][])%R;
}
}
for ( int h = ; h <= hmax; h++ ) {
for ( int w = ; w <= hm[h]; w++ ) {
long long t = ;
for ( int k = ; k < w; k++ ) {
t += (long long)ans[k][h]*wall[w-k][h];
t %= R;
}
ans[w][h] = wall[w][h] > t? wall[w][h]-t:wall[w][h]-t+R;
ans[w][h] %= R;
}
}
} void solve() {
for ( int i = ; i < t; i++ ) {
cout<<ans[vw[i]][vh[i]]<<endl;
}
} int main() {
input();
init();
solve();
return ;
}

sb一般的代码

最近老师安排的事情比较多,,,书看的也慢了。。。简直是弱爆了。。。

legoblock秀上限的更多相关文章

  1. 易企秀微场景2016最新完整版V10.5,小编亲测修复众多错误

    易企秀V10.5更新说明1.修复拨号英文错误2.修复转送场景问题3.修复设置场景密码乱码问题4.修复前台批量删除客户图片5.修复数据收集分页问题6.修复图片分类错乱问题7.修复音乐和特效冲突问题8.修 ...

  2. C++ win32线程数上限

    hThread = CreateThread( NULL,  0,  WorkerFunction,  &threadParm,  0, &dwThreadID  ); 这样的创建方法 ...

  3. 开源IM工程“蘑菇街TeamTalk”的现状:一场有始无终的开源秀

    1.前言 随着云IM的发展,已吸引越来越多有IM需求的APP接入.但考虑到云IM无论从商业模式还是运营模式上,还需经过多年的沉淀,才可能真正实现客户与服务商的运营和服务良性循环的双赢局面.在此之前,加 ...

  4. java中泛型上限,下限应用

    v 一.程序中无形之中用到的泛型 import java.util.*; class Person implements Comparable<Person>{ String name; ...

  5. 全球酷站秀:15个顶尖的 CSS3 网站作品

    每天有数以百计的网站推出,其中很多优秀网站被推荐到 CSS 画廊供大家评分和评论,这对于网页设计师来说是很好的灵感来源.今天,我们选择了15个来自全球各地的 CSS3 网站设计作品, 它们都是赢得 C ...

  6. HBase单个RegionServer的region数目上限

    前言 RegionServer维护Master分配给它的region,处理对这些region的IO请求,负责切分在运行过程中变得过大的region, 由于集群性能( 分配的内存和磁盘是有限的 )有限的 ...

  7. CodePen 作品秀:Canvas 粒子效果文本动画

    作品名称——Shape Shifter,基于 Canvas 的粒子图形变换实验.在页面下方的输入框输入文本,上面就会进行变换出对应的粒子效果文本动画. CodePen 作品秀系列向大家展示来自 Cod ...

  8. 泛型的上限和下限的Demo

    Main Class package Comparator.Bean; import java.math.BigDecimal; import java.util.List; import java. ...

  9. 使用eclipse JDT compile class,解决 无法确定 X 的类型参数;对于上限为 X,java.lang.Object 的类型变量 X,不存在唯一最大实例

    ant 命令行方式执行build javac编译class出现 泛型无法转换 无法确定 <X>X 的类型参数:对于上限为 X,java.lang.Object 的类型变量 X,不存在唯一最 ...

随机推荐

  1. Mac下载并编译Google安卓AOSP项目代码

    Mac下载并编译Google安卓AOSP项目代码 参考 https://source.android.com/source/index.html 这两天用Mac下载安卓AOSP源码,且把遇到的问题记下 ...

  2. Mysql在php5中的应用

    1.PHP与mysql建立连接 php.ini加载mysql组件 extension=php_mysql.dll 前的;去掉 extension_dir=””路径是否正确 PHP连接mysql函数 m ...

  3. JSP JS 日期控件的下载、使用及注意事项

    网上流行的时间日期控件比较多,个人觉得My97DatePicker的日期控件不错,值得推荐. 具体的使用过程如下: 1.下载My97DatePicker.rar或 My97DatePickerBeta ...

  4. Spring在代码中获取bean的几种方式(转:http://www.dexcoder.com/selfly/article/326)

    方法一:在初始化时保存ApplicationContext对象 方法二:通过Spring提供的utils类获取ApplicationContext对象 方法三:继承自抽象类ApplicationObj ...

  5. table强制不换行

    用iframe做了一个查询,里面有一个表格,结果当页面内容多的时候挤在了一起. 上图:

  6. AbstractFactory 模式

    ///////////////////////Product.h////////////// #ifndef _PRODUCT_H_ #define _PRODUCT_H_ class Abstrac ...

  7. nginx插件ngx_lua

    ngx_lua是淘宝的维护的产品,真心不错.配置文件包含可以做很多事情的lua脚本. 公司有个产品对注册的广告盒子进行反向代理,这样可以在盒子上做很多事情:和服务器通信,远程控制盒子等等.nginx反 ...

  8. Bootstrap_表单_图标

    在Bootstrap框架中是通过给元素添加“glyphicon”类名来实现,然后通过伪元素“:before”的“content”属性调取对应的icon编码: <span class=" ...

  9. yii2源码学习笔记(五)

    Event是所有事件类的基类.它封装了与事件相关的参数. yii2\base\Event.php <?php /** * @link http://www.yiiframework.com/ * ...

  10. php之上传小案例,根据时间:月日分创建目录并随机生成文件名

    <?php /* 接收文件,并分目录存储,生成随机文件名 1.根据时间戳,并按一定规则创建目录 2.获取文件名的后缀名 3.判断大小 */ //根据月日分计算并创建目录 function mk_ ...