社区讨论

求大佬教萌新(1535),求看搜索代码(30分,其余WA)

学术版参与者 3已保存回复 6

讨论操作

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

当前回复
6 条
当前快照
1 份
快照标识符
@ly9q4jnf
此快照首次捕获于
2024/07/06 14:08
2 年前
此快照最后确认于
2025/11/20 10:53
4 个月前
查看原帖
CPP
#include<iostream>
#include<fstream>
#include<algorithm>
#include<cstring>
using namespace std;
int map[105][105][105],f[1000][1000],x1,y1,z1,r1,c1,r2,c2,ans,sum;
char a;
int dx[4]={-1,0,1,1};
int dy[4]={1,1,-1,0};
int dfs(int x,int y,int z)//xy表示坐标点,z为剩下时间
{
    if(x<=0||x>x1||y<=0||y>y1||f[x][y]==1||z<0) return 0;//超界,树,时间判断
    if(map[x][y][z]!=-1) return map[x][y][z];//记忆
    int way=0; 
    if(z==0&&x==r2&&y==c2) return 1;
   for(int i=0;i<4;i++)
        if(f[x+dx[i]][y+dy[i]]!=1) way+=dfs(x+dx[i],y+dy[i],z-1);//求种数
    map[x][y][z]=way;
    return map[x][y][z];
}
int main()
{
     memset(map,-1,sizeof(map));
	 cin>>x1>>y1>>z1;
     for(int i=1;i<=x1;i++)
        for(int j=1;j<=y1;j++) 
        {
            cin>>a;
            if(a=='*')f[i][j]=1;
            else f[i][j]=0;
        }
        cin>>r1>>c1>>r2>>c2;
        cout<<dfs(r1,c1,z1);
    return 0;
}
求大佬帮忙

回复

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

正在加载回复...