poj 2704 dfs

来源:互联网 发布:2016移动支付数据 编辑:程序博客网 时间:2024/05/16 12:33
import java.util.*;import java.io.*;import java.math.BigInteger;public class Main {    static int[][] arr = new int[34][34];    static BigInteger[][] mark = new BigInteger[34][34];    static BigInteger dfs(int n,int x,int y){        if(x==n-1&&y==n-1) return BigInteger.ONE;        if(arr[x][y]==0) return BigInteger.ZERO;        if(!mark[x][y].equals(BigInteger.ZERO)) return mark[x][y];        BigInteger value = BigInteger.ZERO;        if(x+arr[x][y]<n){            mark[x+arr[x][y]][y] = dfs(n,x+arr[x][y],y);            value = value.add(mark[x+arr[x][y]][y]);        }        if(y+arr[x][y]<n){            mark[x][y+arr[x][y]] = dfs(n,x,y+arr[x][y]);            value = value.add(mark[x][y+arr[x][y]]);        }        return value;    }    public static void main(String[] args) throws Exception {        Scanner cin = new Scanner(System.in);        while(true){           int num = cin.nextInt();           if(num==-1) break;           for(int i=0;i<num;i++){               String t = cin.next();               Arrays.fill(arr[i], 0);               Arrays.fill(mark[i], BigInteger.ZERO);               for(int j=0;j<num;j++){                   arr[i][j] = t.charAt(j)-'0';               }           }           System.out.println(dfs(num,0,0));        }    }}

怎么记忆化dfs 比单调bfs还慢,我哪里写的不好。
原创粉丝点击