zoukankan      html  css  js  c++  java
  • DFS的简单应用(zoj2110,poj1562)

    zoj2110

    简单的dfs应用,注意have数组的处理

    #include<iostream>
    #include<cstdio>
    #include<cstdlib>
    #include<cstring>
    #include<string>
    #include<cmath>
    #include<map>
    #include<set>
    #include<list>
    #include<deque>
    #include<vector>
    #include<algorithm>
    #include<stack>
    #include<queue>
    #include<cctype>
    #include<sstream>
    using namespace std;
    #define pii pair<int,int>
    #define LL long long int
    const double eps=1e-10;
    const int INF=1000000000;
    const int maxn=7+3;
    
    int n,m,T;
    char Map[maxn][maxn];
    int si,sj;
    int dx[4]={0,0,1,-1};
    int dy[4]={1,-1,0,0};
    int have[maxn][maxn];
    
    bool dfs(int x,int y,int t)
    {
        int tx,ty;
        have[x][y]=0;
        bool ans=false;
        for(int i=0;i<4;i++)
        {
            tx=x+dx[i];
            ty=y+dy[i];
            if(tx>=0&&tx<n&&ty>=0&&ty<m)
            {
                if(Map[tx][ty]=='D'&&T==t+1)
                {
                    return true;
                }
                else if(Map[tx][ty]=='.'&&have[tx][ty]==1)
                {
                    ans=dfs(tx,ty,t+1);
                    if(ans) return true;
                }
            }
        }
        have[x][y]=1;
        return false;
    }
    
    int main()
    {
        //freopen("in1.txt","r",stdin);
        //freopen("out.txt","w",stdout);
        while(scanf("%d%d%d",&n,&m,&T)==3)
        {
            getchar();
            if(n==0&&m==0&&T==0) break;
            for(int i=0;i<n;i++)
            {
                for(int j=0;j<m;j++)
                {
                    scanf("%c",&Map[i][j]);
                    have[i][j]=1;
                    if(Map[i][j]=='S')
                    {
                        si=i;sj=j;//note the starting point
                    }
                }
                getchar();
            }
            /*for(int i=0;i<n;i++)
            {
                puts(Map[i]);
            }*/
            //printf("%d %d
    ",si,sj);
            if(dfs(si,sj,0))
            {
                puts("YES");
            }
            else puts("NO");
        }
        //fclose(stdin);
        //fclose(stdout);
        return 0;
    }
    zoj2110

     poj1562

    #include<iostream>
    #include<cstdio>
    #include<cstdlib>
    #include<cstring>
    #include<string>
    #include<cmath>
    #include<map>
    #include<set>
    #include<list>
    #include<deque>
    #include<vector>
    #include<algorithm>
    #include<stack>
    #include<queue>
    #include<cctype>
    #include<sstream>
    using namespace std;
    #define pii pair<int,int>
    #define LL long long int
    const double eps=1e-10;
    const int INF=1000000000;
    const int maxn=100+5;
    
    char Map[maxn][maxn];
    int n,m,ans;
    int used[maxn][maxn];
    int dx[8]={1,1,1,-1,-1,-1,0,0};
    int dy[8]={0,-1,1,0,1,-1,1,-1};
    
    void dfs(int x,int y)
    {
        used[x][y]=1;
        //cout<<x<<' '<<y<<endl;
        int tx,ty;
        for(int i=0;i<8;i++)
        {
            tx=x+dx[i];
            ty=y+dy[i];
            if(tx>=0&&ty>=0&&tx<n&&ty<m)
            {
                if(Map[tx][ty]=='@'&&used[tx][ty]==0)
                {
                    dfs(tx,ty);
                }
            }
        }
        return;
    }
    
    int main()
    {
        //freopen("in1.txt","r",stdin);
        //freopen("out.txt","w",stdout);
        while(scanf("%d%d",&n,&m)==2)
        {
            //getchar();
            if(n==0&&m==0) break;
            ans=0;
            memset(used,0,sizeof(used));
    
            for(int i=0;i<n;i++)
            {
                scanf("%s",Map[i]);
            }
            /*for(int i=0;i<n;i++)
            {
                for(int j=0;j<m;j++)
                {
                    cout<<Map[i][j];
                }
                puts("");
            }*/
            for(int i=0;i<n;i++)
            {
                for(int j=0;j<m;j++)
                {
                    if(Map[i][j]=='@'&&used[i][j]==0)
                    {
                        ans++;
                        dfs(i,j);
                    }
                }
            }
            printf("%d
    ",ans);
        }
        //fclose(stdin);
        //fclose(stdout);
        return 0;
    }
    poj1562
  • 相关阅读:
    VBoxManage命令详解
    十条nmap常用的扫描命令
    2015-12-16 第八天笔记整理-第二部分
    2015-12-13 第八天笔记整理-第一部分
    2015-12-06 第七天课程笔记
    2015-12-04 学习笔记整理
    2015-11-22 第五天
    选择控制语句和循环结构
    数据类型和运算符
    常用DOS指令
  • 原文地址:https://www.cnblogs.com/zywscq/p/4819985.html
Copyright © 2011-2022 走看看