UVA-11573 - Ocean Currents(简单搜索)

题意:求A到B所需要的能量,顺着水流走不需要能量,否则每走一步需要需要1个单位能量.

分析:BFS+优先队列..

太弱了,感觉这题放在比赛估计会写不出来,囧啊,,搜索都快不会了...

// File Name: 11573.cpp
// Author: Zlbing
// Created Time: 2013/3/28 18:38:50

#include<iostream>
#include<string>
#include<algorithm>
#include<cstdlib>
#include<cstdio>
#include<set>
#include<map>
#include<vector>
#include<cstring>
#include<stack>
#include<cmath>
#include<queue>
using namespace std;
#define CL(x,v); memset(x,v,sizeof(x));
#define INF 0x3f3f3f3f
#define LL long long
#define REP(i,r,n) for(int i=r;i<=n;i++)
#define RREP(i,n,r) for(int i=n;i>=r;i--)
#define MAXN 1005
int G[MAXN][MAXN];
bool vis[MAXN][MAXN];
int d[MAXN][MAXN];
int n,m;
struct node{
    int x,y,len;
    bool operator <(const node &a)const{
        return len>a.len;
    }
};
node change(node t,int k)
{
    if(G[t.x][t.y]==k)
        t.len--;
    if(k==0)
        t.x--;
    if(k==1)
        t.x--,t.y++;
    if(k==2)
        t.y++;
    if(k==3)
        t.y++,t.x++;
    if(k==4)
        t.x++;
    if(k==5)
        t.x++,t.y--;
    if(k==6)
        t.y--;
    if(k==7)
        t.y--,t.x--;
    t.len++;
    return t;
}
int bfs(node st,node ed)
{
    priority_queue<node> Q;
    while(!Q.empty())Q.pop();
    CL(vis,0);
    CL(d,-1);
    Q.push(st);
    d[st.x][st.y]=0;
    while(!Q.empty())
    {
        node t=Q.top();
        Q.pop();
        if(t.x==ed.x&&t.y==ed.y)return t.len;
        for(int i=0;i<8;i++)
        {
            node tmp=change(t,i);
            if(tmp.x<1||tmp.x>n||tmp.y<1||tmp.y>m)
                continue;
            if(d[tmp.x][tmp.y]!=-1&&tmp.len>=d[tmp.x][tmp.y])
                continue;
            d[tmp.x][tmp.y]=tmp.len;
            Q.push(tmp);
        }
    }
    return -1;
}
int main()
{
    while(~scanf("%d%d",&n,&m))
    {
        REP(i,1,n)
            REP(j,1,m)
            scanf("%1d",&G[i][j]);
        int N;
        scanf("%d",&N);
        node st,ed;
        while(N--)
        {
            scanf("%d%d",&st.x,&st.y);
            scanf("%d%d",&ed.x,&ed.y);
            st.len=0;
            int ans=bfs(st,ed);
            printf("%d\n",ans);
        }
    }
    return 0;
}

 

转载于:https://www.cnblogs.com/arbitrary/archive/2013/03/28/2987401.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值