码迷,mamicode.com
首页 > 其他好文 > 详细

uva--232(字符串模拟)

时间:2015-07-29 12:13:06      阅读:98      评论:0      收藏:0      [点我收藏+]

标签:acm   uva   

点击打开链接


这是一道字符串模拟题,题意大概是给定一个m*n的网格,黑格用‘*’表示,白格有一个字母,如果一个白格左边或者上面没有黑格子,则称为一个起始格。

然后找出所有横向单词和竖向单词,注意这个地方的横向单词指从一个起始格开始一直往右或者往下,直到遇见黑格子或者出界,并且每个字母在找横向或者竖向单词时只能用一

次 ,所以分为两个步骤,横向找和竖向找,每次判断该格子是不是起始格,并且是否在前面的单词中用过,若没用过就找下去,用过了则继续往下找起始格。

#include <iostream>
#include <cstdio>
#include <string.h>
#include <map>
#include <stack>
#include <queue>
#include <algorithm>
#include <math.h>
#include <vector>
#include <set>
#define from(i,a,n)   for(int i=a;i<n;i++)
#define refrom(i,n,a) for(int i=n;i>=a;i--)
#define EPS 1e-10
#define mod 1000000007
using namespace std;

const double INF=0x3f3f3f3f;
const int MAX =11;
char puzzle[MAX][MAX],record[MAX][MAX];//这里的record数组用来记录起始格是否已经用于构成单词
int r,c,pos;

void across()
{
    int cnt=0;
    memset(record,0,sizeof(record));
    printf("Across\n");
    from(i,0,r)
    {
        from(j,0,c)//从左往右,从上往下扫描
        {
            int y=j;
            if(i==0&&puzzle[i][j]!='*')//第一行所有不是黑格子的都是起始格
            {
                cnt++;
                if(!record[i][j]) printf("%3d.",cnt);//如果该起始格没有用过,则一定可以找到一个单词
                else continue;
                while(puzzle[i][y]!='*'&&y<c)//往右输出,一直到遇见黑格子或者越界
                {
                    if(!record[i][y])
                    {
                        printf("%c",puzzle[i][y]);
                        record[i][y++]=1;
                    }
                    else break;
                }
                printf("\n");
                continue;
            }
            if(j==0&&puzzle[i][j]!='*')//第一列所有不是黑格子的但是起始格
            {
                cnt++;
                if(!record[i][j]) printf("%3d.",cnt);
                else continue;
                while(puzzle[i][y]!='*'&&y<c)
                {
                    if(!record[i][y])
                    {
                        printf("%c",puzzle[i][y]);
                        record[i][y++]=1;
                    }
                    else break;
                }
                printf("\n");
                continue;
            }
            if(puzzle[i][j]!='*'&&(puzzle[i][j-1]=='*'||puzzle[i-1][j]=='*'))//不是黑格子并且左边或者上面是黑格子的
            {
                cnt++;
                if(!record[i][j]) printf("%3d.",cnt);
                else continue;
                while(puzzle[i][y]!='*'&&y<c)
                {
                    if(!record[i][y])
                    {
                        printf("%c",puzzle[i][y]);
                        record[i][y++]=1;
                    }
                    else break;
                }
                printf("\n");
                continue;
            }
        }
    }
    return ;
}

void down()
{
    int cnt=0;
    memset(record,0,sizeof(record));
    printf("Down\n");
    from(i,0,r)
    {
        from(j,0,c)
        {
            int x=i;
            if(i==0&&puzzle[i][j]!='*')
            {
                cnt++;
                if(!record[i][j]) printf("%3d.",cnt);
                else continue;
                while(puzzle[x][j]!='*'&&x<r)
                {
                    if(!record[x][j])
                    {
                        printf("%c",puzzle[x][j]);
                        record[x++][j]=1;
                    }
                    else break;
                }
                printf("\n");
                continue;
            }
            if(j==0&&puzzle[i][j]!='*')
            {
                cnt++;
                if(!record[i][j]) printf("%3d.",cnt);
                else continue;
                while(puzzle[x][j]!='*'&&x<r)
                {
                    if(!record[x][j])
                    {
                        printf("%c",puzzle[x][j]);
                        record[x++][j]=1;
                    }
                    else break;
                }
                printf("\n");
                continue;
            }
             if(puzzle[i][j]!='*'&&(puzzle[i][j-1]=='*'||puzzle[i-1][j]=='*'))
            {
                cnt++;
                if(!record[i][j]) printf("%3d.",cnt);
                else continue;
                while(puzzle[x][j]!='*'&&x<r)
                {
                    if(!record[x][j])
                    {
                        printf("%c",puzzle[x][j]);
                        record[x++][j]=1;
                    }
                    else break;
                }
                printf("\n");
                continue;
            }
        }
    }
    return ;
}

int main()
{
    int t=0;
    while(cin>>r)
    {
        if(r==0) break;
        cin>>c;
        getchar();
        from(i,0,r)
        gets(puzzle[i]);
        if(t) printf("\n");
        printf("puzzle #%d:\n",++t);
        across();//横向找
        down();//竖向找
    }
    return 0;
}

具体代码如下:


版权声明:本文为博主原创文章,未经博主允许不得转载。

uva--232(字符串模拟)

标签:acm   uva   

原文地址:http://blog.csdn.net/gklzc0608/article/details/47124883

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!