| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1115 人关注过本帖
标题:大牛们,帮忙看一下poj1101,貌似连连看的一个题目!
取消只看楼主 加入收藏
落叶深蓝色
Rank: 8Rank: 8
来 自:山东
等 级:蝙蝠侠
帖 子:319
专家分:807
注 册:2010-12-8
结帖率:100%
收藏
已结贴  问题点数:100 回复次数:6 
大牛们,帮忙看一下poj1101,貌似连连看的一个题目!
题目的描述太多了,发个网址上来吧http://
像连连看一样,求的是两个点之间用了几个线段~!最短的!
程序代码:
#include <iostream>
#include <memory.h>
#include <cstdio>
#include <queue>
using namespace std;
int w,h;
int x1,y1,x2,y2;
char str[80][80];
int vis[80][80],cnt;
int x[4] = {1, -1, 0, 0};
int y[4] = {0, 0, 1, -1};
queue<struct Node> q;
struct Node
{
    int x;
    int y;
};
struct Node tmp,top;
int main()
{
    while(cin>>w>>h,w&&h)
    {
        cnt=1;
        getchar();
        for(int i = 1; i <= h; i++)
            gets(&str[i][1]);
        for(int j=0; j<=w; j++)
            str[0][j]=str[h+1][j]=' ';
        for(int i=0; i<=h; i++)
            str[i][0]=str[i][w+1]=' ';
        while(cin>>y1>>x1>>y2>>x2)
        {
            if(x1==0&&x2==0&&y1==0&&y2==0)
                break;
            for(int i=0; i<=h+1; i++)
            {
                memset(str[i],0,sizeof(str[i]));
                memset(vis[i],-1,sizeof(vis[i]));
            }
            tmp.x=x1;
            tmp.y=y1;
            q.push(tmp);
            vis[x1][y1]=0;
            while(!q.empty())
            {
                top=q.front();
                q.pop();
                for(int i=0; i<4; i++)
                {
                    tmp.x=top.x+x[i];
                    tmp.y=top.y+y[i];
                    while(str[tmp.x][tmp.y]==' '&&top.x+x[i]>=0&&top.x+x[i]<=h+1&&top.y+y[i]>=0&&top.y+y[i]<=w+1&&!vis[top.x+x[i]][top.y+y[i]])
                    {
                        q.push(tmp);
                        vis[tmp.x][tmp.y]=vis[top.x][top.y]+1;
                        tmp.x+=x[i];
                        tmp.y+=y[i];
                    }
                }
            }
            if(vis[x2][y2]==-1)
                printf("Pair %d: impossible.\n", cnt++);
            else
                printf("Pair %d: %d segments.\n", cnt++, vis[x2][y2]);
        }
    }
    return 0;
}
这是我用BFS做的,可是不太对,希望大家指出错误之处,先谢谢啦!
搜索更多相关主题的帖子: color 
2011-10-26 16:21
落叶深蓝色
Rank: 8Rank: 8
来 自:山东
等 级:蝙蝠侠
帖 子:319
专家分:807
注 册:2010-12-8
收藏
得分:0 
怎么木有人啊!
2011-10-26 16:42
落叶深蓝色
Rank: 8Rank: 8
来 自:山东
等 级:蝙蝠侠
帖 子:319
专家分:807
注 册:2010-12-8
收藏
得分:0 
回复 3楼 beyondyf
然后呢?
2011-10-26 17:03
落叶深蓝色
Rank: 8Rank: 8
来 自:山东
等 级:蝙蝠侠
帖 子:319
专家分:807
注 册:2010-12-8
收藏
得分:0 
才疏学浅,没听过,要不你做做,写点注释啥的,咱也学学@!
2011-10-26 17:27
落叶深蓝色
Rank: 8Rank: 8
来 自:山东
等 级:蝙蝠侠
帖 子:319
专家分:807
注 册:2010-12-8
收藏
得分:0 
回复 7楼 Devil_W
你看看我错在哪里了?我输出的都是impossible.
2011-10-26 17:28
落叶深蓝色
Rank: 8Rank: 8
来 自:山东
等 级:蝙蝠侠
帖 子:319
专家分:807
注 册:2010-12-8
收藏
得分:0 
第一:我没看你的,自己AC了,9485039 sdjzuLH 1101 Accepted 236K 16MS C++ 1812B 2011-10-26 19:42:47   
第二,分肯定你的啊,就你自己看了!
2011-10-26 19:45
落叶深蓝色
Rank: 8Rank: 8
来 自:山东
等 级:蝙蝠侠
帖 子:319
专家分:807
注 册:2010-12-8
收藏
得分:0 
程序代码:
#include <iostream>
#include <memory.h>
#include <cstdio>
#include <queue>
using namespace std;
int w,h;
int x1,y1,x2,y2,c1=1;
char str[80][80];
int vis[80][80],cnt;
int x[4] = {1, -1, 0, 0};
int y[4] = {0, 0, 1, -1};
struct Node
{
    int x;
    int y;
};
struct Node tmp,top;
queue<struct Node> q;
int main()
{
    while(cin>>w>>h,w&&h)
    {
        cnt=1;
        getchar();
        for(int i = 1; i <= h; i++)
            gets(&str[i][1]);
        for(int j=0; j<=w; j++)
            str[0][j]=str[h+1][j]=' ';
        for(int i=0; i<=h; i++)
            str[i][0]=str[i][w+1]=' ';
            printf("Board #%d:\n", c1++);
        while(cin>>y1>>x1>>y2>>x2)
        {
            if(x1==0&&x2==0&&y1==0&&y2==0)
                break;
            memset(vis,0,sizeof(vis));
            str[x2][y2]=' ';
            tmp.x=x1;
            tmp.y=y1;
            q.push(tmp);
            vis[x1][y1]=0;
            while(!q.empty())
            {
                top=q.front();q.pop();
                for(int i=0; i<4; i++)
                {
                    tmp.x=top.x+x[i];
                    tmp.y=top.y+y[i];
                    while(str[tmp.x][tmp.y]==' '&&tmp.x>=0&&tmp.x<=h+1&&tmp.y>=0&&tmp.y<=w+1&&!vis[tmp.x][tmp.y])
                    {
                        q.push(tmp);
                        vis[tmp.x][tmp.y]=vis[top.x][top.y]+1;
                        tmp.x+=x[i];
                        tmp.y+=y[i];
                    }
                }
            }
            if(vis[x2][y2]==0)
                printf("Pair %d: impossible.\n", cnt++);
            else
                printf("Pair %d: %d segments.\n", cnt++, vis[x2][y2]);
                str[x2][y2]='X';
        }
        cout<<endl;
    }
    return 0;
}
修改后的代码!
2011-10-26 19:45
快速回复:大牛们,帮忙看一下poj1101,貌似连连看的一个题目!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.038587 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved