社区讨论

P1002 40分求助

灌水区参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@lulyu9e7
此快照首次捕获于
2024/04/05 09:07
2 年前
此快照最后确认于
2024/04/05 11:44
2 年前
查看原帖

P1002

CPP
#include<bits/stdc++.h>
using namespace std;
long long n,m,nn,mm,vis[40][40],ans=0;//n h  m l
void dfs(int bx,int by){
	if(bx==n && by==m)ans++;
	int h[]={1,0};//↓  → 
	int l[]={0,1};
	for(int i=0;i<2;i++){
		int t1=bx+h[i],t2=by+l[i];
		if(vis[t1][t2]==0 && t1<=n && t1>=0 && t2<=m && t2>=0){
			vis[t1][t2]=1;
			dfs(t1,t2);
			vis[t1][t2]=0;
		}
	}
}
int main(){
  cin>>n>>m>>nn>>mm;
  for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			if(i==nn && j==mm || i==nn-2 && j==mm-1 || i==nn-2 && j==mm+1 || i==nn-1 && j==mm-2 || i==nn-1 && j==mm+2 || i==nn+1 && j==mm-2 || i==nn+1 && j==mm+2 || i==nn+2 && j==mm-1 || i==nn+2 && j==mm+1){
				vis[i][j]=1;
			}
		}
  }
  dfs(0,0); 
  cout<<ans<<endl;
  return 0;
}


回复

2 条回复,欢迎继续交流。

正在加载回复...