1 条题解

  • 1
    @ 2025-11-12 22:08:59

    这道题目是简单的搜索,那些TLE的同学我比较不理解,请你们仔细对照并找出错误之处(骗分的一边去)。

    #include<bits/stdc++.h>
    using namespace std;
    int t,n,k,z;
    char a[51][51];
    void dfs(int x,int y,int k1,char f){
    	if(x==n&&y==n){
    		z++;
    		return;
    	}
    	if(x+1<=n&&a[x+1][y]=='.'){
    		if(f=='d'||f=='x'){
    			dfs(x+1,y,k1,'d');
    		}
    		else{
    			if(k1<k){
    				dfs(x+1,y,k1+1,'d');
    			}
    		}
    	}
    	if(y+1<=n&&a[x][y+1]=='.'){
    		if(f=='r'||f=='x'){
    			dfs(x,y+1,k1,'r');
    		}
    		else{
    			if(k1<k){
    				dfs(x,y+1,k1+1,'r');
    			}
    		}
    	}
    }
    int main(){
    	cin>>t;
    	while(t--){
    		cin>>n>>k;
    		for(int i=1;i<=n;i++){
    			for(int j=1;j<=n;j++){
    				cin>>a[i][j];
    			}
    		}
    		if(a[1][2]=='H'&&a[2][1]=='H'){
    			cout<<0<<endl;
    			continue;
    		}
    		z=0;
    		dfs(1,1,0,'x');
    		cout<<z<<endl;
    	}
    	return 0;
    }
    

    信息

    ID
    2822
    时间
    1000ms
    内存
    256MiB
    难度
    9
    标签
    递交数
    74
    已通过
    7
    上传者