zoukankan      html  css  js  c++  java
  • BFS——BMW图形文字识别

    有一些由“_"和"#"组成的图形,图形中由"#"拼成了"B"、"M"、"W"三种字母,。用程序识别这些字母,统计三个字母的个数。

    ___###############________________________________

    ___###################____________________________

    ___#####################__________________________
    ___#####_____________#####________________________
    ___#####_______________###________________________
    ___#####_______________###________________________
    ___#####_______________###________________________
    ___#####_____________#####________________________
    ___#####___________#####__________________________
    ___###################____________________________
    ___###################____________________________
    ___#####___________#######________________________
    ___#####_______________###________________________
    ___#####_______________#####______________________
    ___#####_______________#####______________________
    ___#####_______________#####______________________
    ___#####_______________#####______________________
    ___#####_____________#####________________________
    ___#######################________________________
    ___###################____________________________

    1 0 0

    先BFS判断联通块

    在判断首行间隔数目

    View Code
    #include<stdio.h>
    #include<iostream>
    #include<queue>
    #include<string.h>
    using namespace std;

    int hash1[209][209];
    int map[209][209];
    int ne[209][209];
    int diri[4]={0,-1,0,1};
    int dirj[4]={-1,0,1,0};

    int used[10099];

    struct data
    {
    int ni,nj;
    };

    int n,m;

    void bfs(int x,int y,int add)
    {
    queue<data>qq;
    int i,j;
    data f,s,t;
    f.ni=x;
    f.nj=y;
    qq.push(f);
    while(!qq.empty())
    {
    s=qq.front();
    qq.pop();
    for(i=0;i<=3;i++)
    {
    t.ni=s.ni+diri[i];
    t.nj=s.nj+dirj[i];

    if(t.ni>=1&&t.ni<=n&&t.nj>=1&&t.nj<=m&&(hash1[t.ni][t.nj]==0)&&map[t.ni][t.nj]==1)
    {
    hash1[t.ni][t.nj]=add;
    qq.push(t);
    }
    }
    }
    }

    int main()
    {
    char temp;
    while(scanf("%d%d",&n,&m)!=EOF)
    {
    memset(hash1,0,sizeof(hash1));
    memset(used,0,sizeof(used));

    int i,j;
    char ss[1009];
    for(i=1;i<=n;i++)
    {
    //getchar();
    scanf("%s",ss);
    for(j=1;j<=m;j++)
    {
    temp=ss[j-1];
    if(temp=='_')
    map[i][j]=0;
    else
    map[i][j]=1;
    }
    }


    int add=1;
    for(i=1;i<=n;i++)
    {
    for(j=1;j<=m;j++)
    {
    if(hash1[i][j]==0&&map[i][j]==1)
    {
    bfs(i,j,add);
    add++;
    }
    }
    }
    /*
    for(i=1;i<=n;i++)
    {
    for(j=1;j<=m;j++)
    {
    printf("%d",hash1[i][j]);
    }
    printf("\n");
    }
    */

    add=1;
    int k;
    int B=0,M=0,W=0;
    for(i=1;i<=n;i++)
    {
    for(j=1;j<=m;j++)
    {
    if(hash1[i][j]==0)continue;
    if(used[hash1[i][j]]==1)continue;

    add==hash1[i][j];

    int temp=1;
    for(k=j+1;k<=m;k++)
    {
    if(hash1[i][k]!=0&&hash1[i][k]!=add)
    {
    break;
    }

    if(hash1[i][k]!=0&&used[hash1[i][k]]==0)
    {
    if(hash1[i][k-1]==0)
    temp++;
    }

    }
    j=k;

    used[add]=1;
    if(temp==1)
    {
    // printf("%d %d\n",i,j);
    B++;
    }
    if(temp==2)
    M++;
    if(temp==3)
    W++;
    add++;
    }
    }

    printf("%d %d %d\n",B,M,W);

    }
    return 0;
    }





  • 相关阅读:
    如何进行端到端开发? | 我的物联网成长记
    华为OceanConnect物联网平台概念全景 | 我的物联网成长记
    使用T4模板生成MySql数据库实体类
    Windows Server 创建环回网卡
    使用Asp.Net Identity 2.0 认证邮箱激活账号(附DEMO)
    Agile已死, Agility长存
    ASP.NET Identity 使用 RoleManager 进行角色管理 (VS2013RC)
    Visual Studio调试技巧 -- Attach to Process
    一文搞懂 Elasticsearch 之 Mapping
    看完这篇还不会 Elasticsearch 搜索,那我就哭了!
  • 原文地址:https://www.cnblogs.com/huhuuu/p/2404989.html
Copyright © 2011-2022 走看看