Hustwei


私信TA

用户名:HUSTwei

访问量:3598

签 名:

等  级
排  名 12864
经  验 897
参赛次数 0
文章发表 7
年  龄 0
在职情况 学生
学  校 华中科技大学
专  业

  自我简介:

解题思路:利用记忆化递归进行搜索

注意事项:注意将终点dp[n][m]设为1

参考代码:

#pragma GCC optimize(1)
#pragma GCC optimize(2)
#pragma GCC optimize(3,"Ofast","inline")
#include<iostream>
#define None -1
using namespace std;
//记忆化递归
int n,m;//行数列数 
int dp[31][31]={0};//dp[i][j]存储从(i,j)到(n,m)的方式数 
int path(int i,int j){
	if(dp[i][j]!=None) return dp[i][j];
	int right_path=0;//向右走后的方式数 
	int down_path=0;//向下走后的方式数 
	if(!(i%2==0&&(j+1)%2==0)&&j!=m){
		right_path=path(i,j+1);
		//cout<<"right:"<<"("<<i<<","<<j<<")->("<<i<<","<<j+1<<")"<<endl;
	} 
	if(!(j%2==0&&(i+1)%2==0)&&i!=n){
		down_path=path(i+1,j);
		//cout<<"down:"<<"("<<i<<","<<j<<")->("<<i+1<<","<<j<<")"<<endl;
	}
	dp[i][j]=right_path+down_path;
	return dp[i][j];
} 
int main(){
	cin>>n>>m;
	for(int i=1;i<=n;++i){
		for(int j=1;j<=m;++j){
			dp[i][j]=None;
		}
	}
	dp[n][m]=1;
	cout<<path(1,1);
}


 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区