fork(1) download
  1. #include<stdio.h>
  2. #include<iostream>
  3. #include<algorithm>
  4. using namespace std;
  5. int input[11][11], check[11][11], answer = 0, N;
  6. void calculate(int i, int j)
  7. {
  8. if(i == N and j == N)
  9. answer++;
  10. check[i][j] = 1;
  11. if((j + 1) <= N and check[i][j + 1] == 0 and input[i][j + 1] == 0)
  12. calculate(i, j + 1);
  13. if((i + 1) <= N and check[i + 1][j] == 0 and input[i + 1][j] == 0)
  14. calculate(i + 1, j);
  15. if((j - 1) >= 1 and check[i][j - 1] == 0 and input[i][j - 1] == 0)
  16. calculate(i, j - 1);
  17. if((i - 1) >= 1 and check[i - 1][j] == 0 and input[i - 1][j] == 0)
  18. calculate(i - 1, j);
  19. check[i][j] = 0;
  20. }
  21.  
  22.  
  23. int main()
  24. {
  25. int i, j;
  26. scanf("%d", &N);
  27. for(i = 1;i <= N;i++){
  28. for(j = 1;j <= N;j++){
  29. scanf("%d", &input[i][j]);
  30. check[i][j] = 0;
  31. }
  32. }
  33. calculate(1,1);
  34. printf("%d\n", answer);
  35. return 0;
  36. }
  37.  
Success #stdin #stdout 0s 3344KB
stdin
7
0 0 1 0 0 1 0
1 0 1 1 0 0 0
0 0 0 0 1 0 1
1 0 1 0 0 0 0 
1 0 1 1 0 1 0
1 0 0 0 0 1 0
1 1 1 1 0 0 0
stdout
4