dp练习(3)——棋盘问题
设有一个n*m的棋盘(2≤n≤50,2≤m≤50),如下图,在棋盘上有一个中国象棋马。
规定:
1)马只能走日字
2)马只能向右跳
问给定起点x1,y1和终点x2,y2,求出马从x1,y1出发到x2,y2的合法路径条数。

第一行2个整数n和m
第二行4个整数x1,y1,x2,y2
输出方案数
30 30
1 15 3 15
2
2<=n,m<=50
#include "bits/stdc++.h"
using namespace std; long long dp[][];
//int Map[100][100]; int main()
{
int n,m;
scanf("%d%d",&n,&m);
int x1,y1,x2,y2;
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
memset(dp,, sizeof(dp));
// memset(Map,0,sizeof(Map)); dp[y1][x1] = ; if(x2 <= x1) cout << << endl; for(int i=x1;i < x2;i++)
{
for(int j=;j <= n;j++)
{
if(dp[j][i] != )
{
if(j- >= && i+ <= x2) dp[j-][i+] += dp[j][i];
if(j- >= && i+ <= x2) dp[j-][i+] += dp[j][i];
if(j+ <= n && i+ <= x2) dp[j+][i+] += dp[j][i];
if(j+ <= n && i+ <= x2) dp[j+][i+] += dp[j][i];
}
}
}
//
// for(int i=1;i <= n;i++)
// {
// for(int j=1;j <= m;j++)
// {
// cout << dp[i][j] << " ";
// }
// cout << endl;
// } cout << dp[y2][x2] << endl; return ;
}
嘻嘻,智商低就要多刷题
dp练习(3)——棋盘问题的更多相关文章
- POJ 1185 炮兵阵地 (状压dp)(棋盘dp)
		
这题和poj 3254很像,但是更复杂了一些 都属于棋盘里放东西,然后又各种各样的限制,然后求方案或者最大值 (1)上一道题距离要大于1,这道题是大于2.所以判断的时候变成 !(x & (x ...
 - 暑假集训Day2 状压dp  特殊方格棋盘
		
首先声明 : 这是个很easy的题 可这和我会做有什么关系 题目大意: 在n*n的方格棋盘上放置n个车,某些格子不能放,求使它们不能互相攻击的方案总数. 注意:同一行或同一列只能有一个车,否则会相互攻 ...
 - poj 3254 Corn Fields (状压dp)(棋盘dp)
		
状压dp入门题 因为当前行的状态只和上一行有关 所以可以一行一行来做 因为m <= 12所以可以用二进制来表示放了或者没有放 0表示没放,1表示放 f[i][state]表示第i行状态为stat ...
 - 状态压缩动态规划  状压DP
		
总述 状态压缩动态规划,就是我们俗称的状压DP,是利用计算机二进制的性质来描述状态的一种DP方式 很多棋盘问题都运用到了状压,同时,状压也很经常和BFS及DP连用,例题里会给出介绍 有了状态,DP就比 ...
 - [HNOI2007][bzoj1187] 神奇游乐园 [插头dp]
		
题面: 传送门 给定一个四联通棋盘图,每个格子有权值,求一条总权值最大的回路 思路: 插头dp基础教程 棋盘? 回路? n,m<=10? 当然是插头dp啦~\(≧▽≦)/~ 然后发现这道题并不是 ...
 - dp练习集
		
动态规划(DP) // 以下题目来自牛客网 删括号 f[i][j][k] 表示序列s的前i个匹配序列t的前j个,序列s删除部分左括号与右括号数量差为k的情况是否可行 答案为 f[sl][tl][0] ...
 - BZOJ5248:[九省联考2018]一双木棋——题解
		
https://www.lydsy.com/JudgeOnline/problem.php?id=5248 https://www.luogu.org/problemnew/show/P4363#su ...
 - 炮(棋盘DP)
		
一直以为自己写的就是状态压缩,结果写完才知道是个棋盘dp 首先看一下题目 嗯,象棋 ,还是只有炮的象棋 对于方案数有几种,我第一个考虑是dfs,但是超时稳稳的,所以果断放弃 然后记得以前有过和这个题差 ...
 - POJ 1191 棋盘分割(DP)
		
题目链接 题意 : 中文题不详述. 思路 : 黑书上116页讲的很详细.不过你需要在之前预处理一下面积,那样的话之后列式子比较方便一些. 先把均方差那个公式变形, 另X表示x的平均值,两边平方得 平均 ...
 - HDU 2517 / POJ 1191 棋盘分割 区间DP / 记忆化搜索
		
题目链接: 黑书 P116 HDU 2157 棋盘分割 POJ 1191 棋盘分割 分析: 枚举所有可能的切割方法. 但如果用递归的方法要加上记忆搜索, 不能会超时... 代码: #include& ...
 
随机推荐
- Django框架----视图函数补充
			
视图函数的补充 1.视图函数:一定是要包含两个对象的(render源码里面有HttpResponse对象) request对象:----->所有的请求信息 HttpResponse:-- ...
 - C++中公有继承、保护继承、私有继承的区别
			
公有继承时基类中各成员属性保持不变,基类中private成员被隐藏.派生类的成员只能访问基类中的public/protected成员,而不能访问private成员:派生类的对象只能访问基类中的publ ...
 - HCNP学习笔记之子网掩码的计算和划分详细
			
0x00 子网掩码的计算 TCP/IP网间网技术产生于大型主流机环境中,它能发展到今天的规模是当初的设计者们始料未及的.网间网规模的迅速扩展对IP地址模式的威胁并不是它不能保证主机地址的唯一性,而是会 ...
 - web.xml配置详解之listener
			
web.xml配置详解之listener 定义 <listener> <listener-class>nc.xyzq.listener.WebServicePublishLis ...
 - java replaceAll之$替换
			
最近,在开发一个伪代码翻译工具的过程中,遇到个问题,我们在伪代码中使用spring EL的规则,将非变量限定在${"1"}中,解析后根据上下文的类型转换为相应的java类型.在规则 ...
 - 【翻译】std::list::remove - C++ Reference
			
公有成员函数 std::list::remove void remove(const value_type& val); 删除与给定值相等的元素 从容器中删除所有与 val 值相等的元素.li ...
 - 20145106 java实验二
			
1)复数类ComplexNumber的属性 m_dRealPart: 实部,代表复数的实数部分 m_dImaginPart: 虚部,代表复数的虚数部分 public class ComplexNumb ...
 - 20145329 《网络对抗技术》客户端Adobe阅读器渗透攻击
			
两台虚拟机: kali ip:192.168.96.130 windows xp sp3 ip:192.168.96.133 1.kali下打开显示隐藏文件 2.在kali终端中开启msfconsol ...
 - 20145335郝昊《网络攻防》Exp4 MS11_050
			
20145335郝昊<网络攻防>Exp4 MS11_050 实验内容 初步掌握平台matesploit的使用 了解漏洞MS11_050漏洞:use-after-free漏洞,即对象被释放之 ...
 - STM32.BOOT
			
BOOT0 和 BOOT1STM32 三种启动模式对应的存储介质均是芯片内置的,它们是:1)用户闪存 = 芯片内置的?Flash.2)SRAM = 芯片内置的 RAM 区,就是内存啦.3)系统存储器 ...