3 条题解

  • 2
    @ 2023-4-6 19:02:27
    #include<bits/stdc++.h>
    using namespace std;
    int a[11][11];
    int book[11][11],next[8][2]={{-1,0},{-1,1},{0,1},{1,1},{1,0},{1,-1},{0,-1},{-1,-1}},n,g=0;
    void zzh(int x,int y)
    {
    	if(x==1 && y==n)
    	{
    		g=g+1;
    		return;
    	}
    	for(int k=0;k<8;k++)
    	{
    		int tx=x+next[k][0];
    		int ty=y+next[k][1];
    		if(tx<1 || tx>n || ty<1 || ty>n)
    		{
    			continue;
    		}
    		if(a[tx][ty]==0 && book[tx][ty]==0)
    		{
    			book[tx][ty]=1; 
    			zzh(tx,ty);
    			book[tx][ty]=0;
    		}
    	}
    	return;
    }
    int main()
    {
         cin>>n;
         for(int i=1;i<=n;i++)
         {
        	     for(int j=1;j<=n;j++)
        	     {
        		     cin>>a[i][j];
    	     }
         }
    	book[1][1]=1;
    	zzh(1,1);
    	cout<<g;
    	return 0;
    }
    
    • 0
      @ 2023-4-6 19:05:45
      #include<bits/stdc++.h>
      using namespace std;
      int a[10001][10001];
      int book[10001][10001],next[8][2]= {{-1,0},{-1,1},{0,1},{1,1},{1,0},{1,-1},{0,-1},{-1,-1}},n,sum=0;
      void dfs(int x,int y) {
      	if(x==1 && y==n) {
      		sum++;
      		return;
      	}
      	for(int k=0; k<8; k++) {
      		int tx=x+next[k][0];
      		int ty=y+next[k][1];
      		if(tx<1 || tx>n || ty<1 || ty>n)	continue;
      		if(a[tx][ty]==0 && book[tx][ty]==0) {
      			book[tx][ty]=1;
      			dfs(tx,ty);
      			book[tx][ty]=0;
      		}
      	}
      	return;
      }
      int main() {
      	cin>>n;
      	for(int i=1; i<=n; i++) {
      		for(int j=1; j<=n; j++) {
      			cin>>a[i][j];
      		}
      	}
      	book[1][1]=1;
      	dfs(1,1);
      	cout<<sum;
      	return 0;
      }
      
      • -12
        @ 2022-7-15 14:57:07
        #include<bits/stdc++.h>
        using namespace std;
        int flag[8] = {0,0,1,1,1,-1,-1,-1};
        int flag1[8] = {1,-1,0,1,-1,0,1,-1};
        int n, cnt = 0;
        int a[1005][1005], b[10][1005];
        void dfs(int s,int t) {
        	int x, y;
        	if(s == 1 && t == n) {
        		cnt++;
        		return;
        	}
        	for(int i = 0; i < 8; i++) {
        		x = s + flag[i];
        		y = t + flag1[i];
        		if(x > 0 && y > 0 && x <= n && y <= n && a[x][y] == 0 && b[x][y] == 0) {
        			b[x][y] = 1;
        			dfs(x, y);
        			b[x][y] = 0;
        		}
        	}
        	return;
        }
        int main() {
        	cin >> n;
        	for(int i = 1; i <= n; i++) {
        		for(int j = 1; j <= n; j++) {
        			cin >> a[i][j];
        		}
        	}
        	memset(b, 0 ,sizeof(b));
        	b[1][1] = 1;
        	dfs(1, 1);
        	cout << cnt << endl;
        	return 0;
        }
        
        • 1

        信息

        ID
        1110
        时间
        1000ms
        内存
        128MiB
        难度
        6
        标签
        递交数
        152
        已通过
        41
        上传者