洛谷P1002——过河卒
又是洛谷题,要不是有小姐姐不会,我才不想动脑子。先贴一下题目地址https://www.luogu.org/problem/P1002
再贴一下题目:


我们读一下题目,这可不比学校的**算法题,读完一遍没啥感觉。我意识到需要画图了,(噢,我垃圾的画图技术)

因为卒只能向下或者向右,也就是说,除了第一行第一列之外,当前索引上的元素的值都仅由其上方元素与前方元素共同决定。(图中5,6写错应该是1)
A表示卒所在的地方, B表示目的地,M表示马,红色的坐标表示封锁区,格子里的数字表示走到该位置有多少方法。现在我们可以轻易的从图中轻易的发现 Map[i,j] = Map[i-1, j] + Map[i, j-1]; 所以我们可以很轻松的得出状态转移方程
Map[1][1] = 1;
Map[i][j] = MAX(Map[i-1][j]+Map[i][j-1]);//c语言里没有MAX自己写一个去
针对没有MAX又不想写的我,我略微改动了一下状态方程:
Map[1][0] = 1;
Map[i][j] = Map[i-1][j]+Map[i][j-1];
利用了一下空出来的0列,为什么要空出0行和0列呢?因为这个方程Map[i-1][j]+Map[i][j-1] 取到0会产生数组越界然后就RE
顺便说一下为了避免数组越界所以我把输入的数据全部+1,这样就避免了内存泄漏,这道题还专门说明了数据会很大,所以应该用longlong。解决了这几点之后我们就可以写代码了
巴拉巴拉~
贴代码:
#include <stdio.h>
#include <stdbool.h>
#define DEBUG 0
#define Format \
Bx++; \
By++; \
Hx++; \
Hy++; \
map[][] = ; \
H_map[Hx][Hy] = ;
typedef long long ll;
typedef unsigned char uchar; ll map[][] = {};
bool H_map[][] = {};
//限制点
const int Hforbidx[] = {, -, -, , , , , -, -};
const int Hforbidy[] = {, , , , , -, -, -, -}; int main()
{
int Bx, By, Hx, Hy; scanf("%d%d%d%d", &Bx, &By, &Hx, &Hy);
//初始化
Format; //标志点
for (int i = ; i <= ; i++)
{
H_map[Hx + Hforbidx[i]][Hy + Hforbidy[i]] = ;
//测试点1
#if DEBUG
printf("i = %d j = %d\n", Hx + Hforbidx[i], Hy + Hforbidy[i]);
#endif
} for (int i = ; i <= Bx; i++)
{
for (int j = ; j <= By; j++)
{
if (H_map[i][j])
{
//测试点2
#if DEBUG
printf("\n%d\n", H_map[i][j]);
#endif // DEBUG
map[i][j] = ; //被马拦住了记住清零
continue;
}
//状态转移方程
map[i][j] = map[i - ][j] + map[i][j - ];
//测试点2
#if DEBUG
printf("map[%d][%d] = %d\n", i, j, map[i][j]);
if ( == j % )
{
putchar('\n');
}
#endif // DEBUG
}
}
printf("%lld\n", map[Bx][By]); return ;
}
切记,自己先写。
洛谷P1002——过河卒的更多相关文章
- 洛谷 P1002过河卒
洛谷 P1002过河卒 题目描述 棋盘上AA点有一个过河卒,需要走到目标BB点.卒行走的规则:可以向下.或者向右.同时在棋盘上CC点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点 ...
- 洛谷P1002 过河卒 [2017年4月计划 动态规划15]
P1002 过河卒 题目描述 棋盘上A点有一个过河卒,需要走到目标B点.卒行走的规则:可以向下.或者向右.同时在棋盘上C点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点.因此称之 ...
- 洛谷 P1002 过河卒 【棋盘dp】
题目链接:https://www.luogu.org/problemnew/show/P1002 题目描述 棋盘上A点有一个过河卒,需要走到目标B点.卒行走的规则:可以向下.或者向右.同时在棋盘上C点 ...
- 洛谷[P1002]过河卒
原题地址:https://www.luogu.org/problemnew/show/P1002 题目描述 棋盘上A点有一个过河卒,需要走到目标B点.卒行走的规则:可以向下.或者向右.同时在棋盘上C点 ...
- 洛谷P1002 过河卒 题解 动态规划
题目链接:https://www.luogu.com.cn/problem/P1002 题目大意 棋盘上\(A\)点有一个过河卒,需要走到目标\(B\)点.卒行走的规则:可以向下.或者向右.同时在棋盘 ...
- 洛谷P1002 过河卒
关于蒟蒻的我,刚刚接触DP.... 那么就来做一道简单DP吧.... 首先先看题: 题目描述 棋盘上AA点有一个过河卒,需要走到目标BB点.卒行走的规则:可以向下.或者向右.同时在棋盘上CC点有一 ...
- 洛谷P1002 过河卒【dp】
棋盘上AA点有一个过河卒,需要走到目标BB点.卒行走的规则:可以向下.或者向右.同时在棋盘上CC点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点.因此称之为"马拦过河卒 ...
- 洛谷——P1002 过河卒||codevs——T1010 过河卒
https://www.luogu.org/problem/show?pid=1002#sub||http://codevs.cn/problem/1010/ 题目描述 棋盘上A点有一个过河卒,需要走 ...
- 【做题笔记】洛谷P1002过河卒
虽说是 dp 入门题,但还是有很多细节需要注意 如果设 \(f_{x,y}\) 为目标地点为 \((x,y)\) 时走的种数,那么答案就是 \(f_{n,m}\) 在不考虑那只讨厌的马的情况下,对于任 ...
随机推荐
- Linux命令:grep命令 | egrep命令
grep:文本搜素工具,根据用户指定的文本模式对目标文件进行逐行搜索,显示能被模式所匹配到的行 包含三个命令:grep.egrep(相当于grep -E 扩展的正则表达式)和fgrep(相当于grep ...
- Cortex-M3学习小结
- Color Space 和 Color Range
颜色有两个属性Color Range和Color Space 有关Color Space的解释可以看下面两个链接: https://www.jianshu.com/p/facdbab5ac20 htt ...
- redhat 7.6 VI编辑操作
模式一: 浏览模式 0 : 光标到行首 $ : 光标到行尾 gg:光标到首行 G:光标到尾行 yy:复制光标所在行 dd:剪切光标所在行,删除行 y11y:复制光标所在行,往下数,一共10行 p:粘贴 ...
- Python 基础之字符串操作,函数及格式化format
一.字符串的相关操作 1.字符串的拼接 + strvar1 = "我爱你,"strvar2 = "亲爱的姑凉"res = strvar1 + strvar2pr ...
- js通过cookie对两个没有关系的jsp页面进行传值
//Cookie取值 function readCookie (name) { var cookieValue = ""; var search = name + "=& ...
- python之常见模块(time,datetime,random,os,sys,json,pickle)
目录 time 为什么要有time模块,time模块有什么用?(自己总结) 1. 记录某一项操作的时间 2. 让某一块代码逻辑延迟执行 时间的形式 时间戳形式 格式化时间 结构化时间 时间转化 总结: ...
- jgrid异步数据加载
参考:https://blog.csdn.net/hurryjiang/article/details/7077725
- 第1节 storm编程:9、storm与kafka的整合
详见代码. 下图,为设置kafka的首次消费策略,即首次消费的偏移量的示例:
- 华为轮值CEO,富士康却坚持独裁,二者究竟有什么不一样?
谈到深圳龙华的大企业,人们会很自然地想到华为和富士康,两家公司毗邻,有两个门仅仅隔着一条马路,都是世界500强,对国家,对社区的经济发展有着重要贡献,员工压力最大的时候,也都出现过自杀的情况,一个讲究 ...