POJ 3050 Hopscotch

暴力DFS

#include<cstdio>
#include<cstring>
#include<cmath>
#include<vector>
#include<algorithm>
using namespace std;

int a[10][10];
bool flag[2000000];
int ans;
int dir[4][2]={
    {1,0},
    {-1,0},
    {0,1},
    {0,-1}
};


void dfs(int x,int y,int num,int deep)
{
    if(deep==5)
    {
        if(flag[num]==0)
        {
            flag[num]=1;
           // printf("%d\n",num);
            ans++;
        }
        return;
    }

    for(int i=0;i<4;i++)
    {
        int newx=x+dir[i][0];
        int newy=y+dir[i][1];

        if(newx>=1&&newx<=5)
            if(newy>=1&&newy<=5)
                dfs(newx,newy,num*10+a[newx][newy],deep+1);
    }
}

int main()
{
    for(int i=1;i<=5;i++)
        for(int j=1;j<=5;j++)
            scanf("%d",&a[i][j]);
    ans=0; memset(flag,0,sizeof flag);
    for(int i=1;i<=5;i++)
        for(int j=1;j<=5;j++)
            dfs(i,j,a[i][j],0);
    printf("%d\n",ans);

    return 0;
}

 

posted @ 2016-03-28 10:39  Fighting_Heart  阅读(194)  评论(0编辑  收藏  举报