1196:踩方格

题目连接:http://ybt.ssoier.cn:8088/problem_show.php?pid=1196

备递归算法的时候遇到这道题,没有发现递推式,看完网路题解才能推出来

题解如右连接,看完恍然大悟  https://www.cnblogs.com/sjymj/p/5379221.html当然这种方法有点动态规划的意思

题解
l[i]表示最后一步向左走到达第i个格,那么它上一格不能是从右边走得到,r[i]表示最后一步向右走到达第i个格,那么它上一格不能是从左边走得到,u[i]表示最后一步先上走到达第i个格;
 1 #include<iostream>
 2 #include<cstdio>
 3 using namespace std;
 4 int n,ans;
 5 int l[30],r[30],u[30];
 6 int main()
 7 {
 8     cin>>n;
 9     if (n==1) cout<<3;
10       else
11        {
12           l[1]=1;
13           r[1]=1;
14           u[1]=1;
15           for (int i=2;i<=n;i++)
16             {
17                  l[i]=l[i-1]+u[i-1];
18                  r[i]=r[i-1]+u[i-1];
19                  u[i]=l[i-1]+r[i-1]+u[i-1];
20             }
21           ans=l[n]+r[n]+u[n];
22           cout<<ans<<endl;
23        }
24     return 0;
25 }

又找到另外一种题解方式,显然有递推思想也有动态规划的意思 https://blog.csdn.net/g_meteor/article/details/70169748

这道题为一道递推问题,可向上走、左走跟右走,但是需要注意的是往右走的那条路就不能往左走了。即有递推公式a[i]=a[i-1]+(2*a[i-2]+a[i-1]-a[i-2])=2*a[i-1]+a[i-2],a[i-1]表示往上走的那一路种类数,2*a[i-2]+a[i-1]-a[i-2]表示往左右两个方向的种类数。

源代码如下:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 int main()
 4 { int n,i,a[21];
 5   cin>>n;
 6   a[0]=1;
 7   a[1]=3;
 8   for(i=2;i<21;++i)
 9    a[i]=2*a[i-1]+a[i-2];
10   cout<<a[n]<<endl;
11  } 

但两种方法对于蒟蒻来说其实在初期很难想到,毕竟题出自POJ,可想难度

但是面对这样一道典型dfs,我还是可以写出的,悲剧的是居然用了2个小时

主要是调试以下代码就用了1个小时,仅以此代码铭记我的错误

 1 #include<iostream>
 2 using namespace std;
 3 int next[3][2]={{-1,0},{0,1},{1,0}};
 4 int n, cnt=0;
 5 int v[500][500];
 6 void dfs(int x, int y, int step)
 7 {
 8     if(step>=n){
 9         cnt++;
10         return;
11     }
12     for(int i=0; i<3; i++)
13     {
14         int tx=x+next[i][0];
15         int ty=y+next[i][1];
16         if(!v[tx][ty])
17         {
18             v[tx][ty]=1;
19             dfs(tx, ty, step+1);
20             v[tx][ty]=0;
21         }
22     }
23 }
24 int main()
25 {
26     cin>>n;
27     dfs(0, 0, 0);
28     cout<<cnt;
29     return 0;
30 }

调试之后的代码,愉快AC!

 1 #include<iostream>
 2 using namespace std;
 3 int next[3][2]={{-1,0},{0,1},{1,0}};
 4 int n, cnt=0;
 5 int v[1000][1000];//是否被访问过
 6 void dfs(int x, int y, int step)
 7 {
 8     v[x][y]=1;//当前调用即代表改点访问过了
 9     if(step>=n){
10         cnt++;
11         return;
12     }
13     for(int i=0; i<3; i++)
14     {
15         int tx=x+next[i][0];
16         int ty=y+next[i][1];
17         if(!v[tx][ty])
18         {
19             v[tx][ty]=1;
20             dfs(tx, ty, step+1);
21             v[tx][ty]=0;
22         }
23     }
24 }
25 int main()
26 {
27     cin>>n;
28     dfs(500, 500, 0);//注意此处500,500坐标是在第一象限定义了一个起点,因为n≤20所以这样定义就不会数组出现负数了
29     cout<<cnt;
30     return 0;
31 }

睡觉去了!

原文地址:https://www.cnblogs.com/tflsnoi/p/9601912.html

时间: 2024-08-05 19:40:09

1196:踩方格的相关文章

踩方格

踩方格 链接:http://ybt.ssoier.cn:8088/problem_show.php?pid=1196 时间限制: 1000 ms         内存限制: 65536 KB提交数: 139     通过数: 93 [题目描述] 有一个方格矩阵,矩阵边界在无穷远处.我们做如下假设: a.每走一步时,只能从当前方格移动一格,走到某个相邻的方格上: b.走过的格子立即塌陷无法再走第二次: c.只能向北.东.西三个方向走: 请问:如果允许在方格矩阵上走n步,共有多少种不同的方案.2种走

4982:踩方格

4982:踩方格 查看 提交 统计 提问 总时间限制:  1000ms 内存限制:  65536kB 描述 有一个方格矩阵,矩阵边界在无穷远处.我们做如下假设:a.    每走一步时,只能从当前方格移动一格,走到某个相邻的方格上:b.    走过的格子立即塌陷无法再走第二次:c.    只能向北.东.西三个方向走:请问:如果允许在方格矩阵上走n步,共有多少种不同的方案.2种走法只要有一步不一样,即被认为是不同的方案. 输入 允许在方格上行走的步数n(n <= 20) 输出 计算出的方案数量 样例

poj 4982 踩方格

4982:踩方格 查看 提交 统计 提问 总时间限制:  1000ms 内存限制:  65536kB 描述 有一个方格矩阵,矩阵边界在无穷远处.我们做如下假设:a.    每走一步时,只能从当前方格移动一格,走到某个相邻的方格上:b.    走过的格子立即塌陷无法再走第二次:c.    只能向北.东.西三个方向走:请问:如果允许在方格矩阵上走n步,共有多少种不同的方案.2种走法只要有一步不一样,即被认为是不同的方案. 输入 允许在方格上行走的步数n(n <= 20) 输出 计算出的方案数量 样例

踩方格(找规律 递推)

踩方格 时间限制: 1 Sec  内存限制: 128 MB提交: 8  解决: 7[提交][状态][讨论版][命题人:quanxing] 题目描述 有一个方格矩阵,矩阵边界在无穷远处.我们做如下假设: a.每走一步时,只能从当前方格移动一格,走到某个相邻的方格上: b.走过的格子立即塌陷无法再走第二次: c.只能向北.东.西三个方向走: 请问:如果允许在方格矩阵上走n步,共有多少种不同的方案.2种走法只要有一步不一样,即被认为是不同的方案. 输入 允许在方格上行走的步数n(n≤20). 输出 计

【noi 2.6_4982】踩方格(DP)

题意:一个无限大的方格矩阵,能向北.东.西三个方向走.问走N步共有多少种不同的方案. 解法: f[i]表示走 i 格的方案数. 状态转移方程推导如下——设l[i],r[i],u[i]分别为第 i 步向西.东.北的方案数,f[i]为总方案数.l[i]=l[i-1]+u[i-1], r[i]=r[i-1]+u[i-1], u[i]=l[i-1]+r[i-1]+u[i-1]f[i]=l[i]+r[i]+u[i]    =2*l[i-1]+2*r[i-1]+3*u[i-1]    =2*f[i-1]+u

OpenJ_Bailian 4103 踩方格(搜索 动态规划 )

题目传送门OpenJ_Bailian 4103 描述 有一个方格矩阵,矩阵边界在无穷远处.我们做如下假设:a.    每走一步时,只能从当前方格移动一格,走到某个相邻的方格上:b.    走过的格子立即塌陷无法再走第二次:c.    只能向北.东.西三个方向走:请问:如果允许在方格矩阵上走n步,共有多少种不同的方案.2种走法只要有一步不一样,即被认为是不同的方案. 输入 允许在方格上行走的步数n(n <= 20) 输出 计算出的方案数量 样例输入 2 样例输出 7 解题思路: 1.递归:从 (i

noi 9271 奶牛散步

题目链接:http://noi.openjudge.cn/ch0206/9271/ 同noi 踩方格,但是题目有问题,%12345,我也是看了discuss才知道的. #include <bits/stdc++.h> using namespace std; unsigned long long d[1005]; int main() { d[1] = 3; d[2] = 7; for(int i=3;i<=1001;i++) d[i] = (2*d[i-1] + d[i-2])%123

openjudge dp水题记录

当发现自己竟然不会打dp的时候内心是崩溃的,然后按照一年前的刷题记录刷openjudge,然后发现自己准确率比一年前(刚学信竞两个月时)的准确率低得多,已经没救. 列一下最近打的几道sb题 2985:数字组合 描述有n个正整数,找出其中和为t(t也是正整数)的可能的组合方式.如: n=5,5个数分别为1,2,3,4,5,t=5: 那么可能的组合有5=1+4和5=2+3和5=5三种组合方式.输入输入的第一行是两个正整数n和t,用空格隔开,其中1<=n<=20,表示正整数的个数,t为要求的和(1&

2016. 4.10 NOI codevs 动态规划练习

1.codevs1040 统计单词个数 1040 统计单词个数 2001年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 给出一个长度不超过200的由小写英文字母组成的字母串(约定;该字串以每行20个字母的方式输入,且保证每行一定为20个).要求将此字母串分成k份(1<k<=40),且每份中包含的单词个数加起来总数最大(每份中包含的单词可以部分重叠.当选用一个单词之后,其第一个字母不能再用.例如字符串t