hdu 4771 Stealing Harry Potter's Precious

hdu 4771 Stealing Harry Potter's Precious

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

全栈程序员社区此处内容已经被作者隐藏,请输入验证码查看内容
验证码:
请关注本站微信公众号,回复“验证码”,获取验证码。在微信里搜索“全栈程序员社区”或者“www_javaforall_cn”或者微信扫描右侧二维码都可以关注本站微信公众号。

题目:给出一个二维图,以及一个起点,m个中间点,求出从起点出发,到达每一个中间的最小步数。

思路:由于图的大小最大是100*100,所以要使用bfs求出当中每两个点之间的最小距离。然后依据这些步数,建立一个新的图,使用dfs求出最佳步数。

代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#define INF 100000000
using namespace std;
char ma[103][103];
int vis[103][103];
int map[6][6],net[6];
int m,n,k;
struct node
{
    int x,y;
    int k;
}t;
queue<node>q;
int bfs(int x,int y,int l,int r)
{
    memset(vis,0,sizeof(vis));
    while(!q.empty())
    {
        q.pop();
    }
    vis[x][y]=1;
    t.x=x,t.y=y,t.k=0;
    q.push(t);
    while(!q.empty())
    {
        t=q.front();
        q.pop();
        x=t.x;y=t.y;
        if(x==l&&y==r)
        {
            return t.k;
        }
        t.k++;
        if(x>=2&&ma[x-1][y]!='#'&&!vis[x-1][y])
        {
            t.x=x-1;t.y=y;
            vis[t.x][t.y]=1;
            q.push(t);
        }
        if(y>=2&&ma[x][y-1]!='#'&&!vis[x][y-1])
        {
            t.x=x;t.y=y-1;
            vis[t.x][t.y]=1;
            q.push(t);
        }
        if(x+1<=m&&ma[x+1][y]!='#'&&!vis[x+1][y])
        {
            t.x=x+1;t.y=y;
            vis[t.x][t.y]=1;
            q.push(t);
        }
        if(y+1<=n&&ma[x][y+1]!='#'&&!vis[x][y+1])
        {
            t.x=x;t.y=y+1;
            vis[t.x][t.y]=1;
            q.push(t);
        }
    }
    return INF;
}
int ans=INF;
void dfs(int x,int step,int sum)
{
    if(step==k)
    {
        if(ans>sum) ans=sum;
        return;
    }
    for(int i=0;i<=k;i++)
    if(!net[i])
    {
       net[i]=1;
       dfs(i,step+1,sum+map[x][i]);
       net[i]=0;
    }
}
int main()
{
    int d[6][2];
    while(cin>>m>>n,m,n)
    {
        int x=0,y=0,l,r,sum;
        ans=INF;
        for(int i=1;i<=m;i++)
        {
            scanf("%s",&ma[i][1]);
            if(!x)
                for(int j=1;j<=n;j++)
                if(ma[i][j]=='@')
                {
                  x=i,y=j;
                  break;
                }
        }
        d[0][0]=x;d[0][1]=y;
        cin>>k;
        for(int i=1;i<=k;i++)
        {
            cin>>d[i][0]>>d[i][1];
        }
        for(int i=0;i<k;i++)
        {
            x=d[i][0],y=d[i][1];
            for(int j=i+1;j<=k;j++)
            {
                l=d[j][0],r=d[j][1];
                sum=bfs(x,y,l,r);
                if(sum<INF) map[i][j]=map[j][i]=sum;
                else map[i][j]=map[j][i]=INF;
                //cout<<sum<<endl;
            }
        }
        net[0]=1;
        dfs(0,0,0);
        if(ans<INF) cout<<ans<<endl;
        else cout<<-1<<endl;
    }
    return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117918.html原文链接:https://javaforall.net

(0)
上一篇 2021年12月16日 下午6:00
下一篇 2021年12月16日 下午7:00


相关推荐

  • swing58_ML2437A

    swing58_ML2437A给定一个长度为 n 的整数序列,初始时序列为 {1,2,…,n−1,n}。序列中的位置从左到右依次标号为 1∼n。我们用 [l,r] 来表示从位置 l 到位置 r 之间(包括两端点)的所有数字构成的子序列。现在要对该序列进行 m 次操作,每次操作选定一个子序列 [l,r],并将该子序列中的所有数字进行翻转。例如,对于现有序列 1 3 2 4 6 5 7,如果某次操作选定翻转子序列为 [3,6],那么经过这次操作后序列变为 1 3 5 6 4 2 7。请你求出经过 m 次操作后的序列。输入格式第

    2022年8月10日
    9
  • java 排序队列_java实现顺序队列

    java 排序队列_java实现顺序队列packagequeue;importjava.util.Scanner;publicclassArrayQueueLoop{publicstaticvoidmain(String[]args){//TODOAuto-generatedmethodstub//测试代码//测试数组循化队列CircleQueuetestQueue=newCircleQueue(4);//设置的是有效…

    2022年7月16日
    19
  • 如何刷原生android系统版本,小米手机1原生Android4.1系统刷机教程

    如何刷原生android系统版本,小米手机1原生Android4.1系统刷机教程《小米手机1原生Android4.1系统刷机教程》由会员分享,可在线阅读,更多相关《小米手机1原生Android4.1系统刷机教程(4页珍藏版)》请在人人文库网上搜索。1、小米手机1原生Android4.1系统刷机教程各位亲爱的米粉:小米手机1原生Android4.1系统已经正式公测,小米手机1、小米手机1s及小米手机1S青春版均可升级。您可以通过卡刷与线刷两种方式升级至Androi…

    2022年6月19日
    44
  • Java冒泡排序算法

    Java冒泡排序算法java 冒泡排序算法 1 基本思想 对比相邻的元素值 如果满足条件就交换元素值 把较小的元素移动到数组的前面 从小到大排序 把大的元素移动到数组的后面 即交换两个元素的位置 这样较小的元素就像气泡一样从底部上升到顶部 2 算法实现 冒泡算法由双层循环实现 其中外层循环用于控制排序轮数 一般为要排序的数组长度减 1 因为最后一次循环只剩下一个数组元素 不需要对比 同时已经完成排序了 内层循环主

    2026年3月19日
    5
  • pycharm linux激活码-激活码分享

    (pycharm linux激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~AFH5K5BM31-eyJsaWNlb…

    2022年3月30日
    151
  • p2p网络传输协议

    p2p网络传输协议P2P是英文Peer-to-Peer(对等)的简称,又被称为“点对点”。“对等”技术,是一种网络新技术,依赖网络中参与者的计算能力和带宽,而不是把依赖都聚集在较少的几台服务器上。P2P还是英文PointtoPoint(点对点)的简称。它是下载术语,意思是在你自己下载的同时,自己的电脑还要继续做主机上传,这种下载方式,人越多速度越快但缺点是对硬盘损伤比较大(在写的同时还要读),还有对内存占用较…

    2022年7月16日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号