POJ 3411 Paid Roads

POJ 3411 Paid Roads

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

主题链接~~>

做题情绪:先前看过一次,感觉做多了状态压缩之后。再做这题就非常顺手了。

解题思路:  BFS  + 状态压缩

              一个城市能够走多次,so ~ > 须要用状态压缩。開始用了优先队列可是后来发现不能够用。当中例子用优先队列就过不了,于是把标记数组改为记录达到某个城市达到某种 状态的最小花费,假设搜到某个状态花费比当前状态小。更新标记数组的花费。就继续搜下去。否则不向下搜,这样搜出全部的情况就能够了。

(注意推断的时候要推断终点城市是否在状态里,開始有点脑残了推断是否全部城市都到达了)。

代码:

#include<iostream>
#include<sstream>
#include<map>
#include<cmath>
#include<fstream>
#include<queue>
#include<vector>
#include<sstream>
#include<cstring>
#include<cstdio>
#include<stack>
#include<bitset>
#include<ctime>
#include<string>
#include<cctype>
#include<iomanip>
#include<algorithm>
using namespace std  ;
#define INT __int64
#define L(x)  (x * 2)
#define R(x)  (x * 2 + 1)
const int INF = 0x3f3f3f3f ;
const double esp = 0.0000000001 ;  // 问 mod  HDU 5063
const double PI = acos(-1.0) ;
const int mod = 1e9 + 7 ;
const int MY = 10 + 5 ;
const int MX = (1<<10) + 5 ;
int n ,m ;
int vis[MY][MX] ;
struct node
{
    int c1 ,c2 ;
}mp[MY][MY][MY] ;
struct NODE
{
    int x ,cost ,key ;
} ;
int bfs(int x)
{
    int ans = INF ;
    queue<NODE> q ;
    NODE curt ,next ;
    curt.x = x ;  // 终于到达的点
    curt.cost = 0 ;  // 花费
    curt.key = 1 ;  // 状态
    vis[0][1] = 0 ;
    q.push(curt) ;
    while(!q.empty())
    {
        curt = q.front() ;
        q.pop() ;
        if(curt.key &(1<<(n-1)))
            ans = min(ans ,curt.cost) ;
        for(int i = 0 ;i < n ; ++i)
          for(int j = 0 ;j < n ; ++j)
           if(mp[curt.x][i][j].c1 != -1)
           {
              int costA = INF ,costB = INF ;
              next.key  = curt.key ;
              if(next.key&(1<<j)) // 预支点在里面
                   costA = curt.cost + mp[curt.x][i][j].c1 ; // 原先的花费加上当前花费
              costB = curt.cost + mp[curt.x][i][j].c2 ;
              next.cost = min(costA ,costB) ;
              next.x = i ;
              if(!(next.key&(1<<i)))
                     next.key |= (1<<i) ;
              if(vis[i][next.key] > next.cost)
              {
                  vis[i][next.key] = next.cost ;
                  q.push(next) ;
              }
           }
    }
    return  ans ;
}
int main()
{
    //freopen("input.txt" ,"r" ,stdin) ;
    int u ,v ,t ,c1 ,c2 ;
    while(~scanf("%d%d" ,&n ,&m))
    {
        memset(mp ,-1 ,sizeof(mp)) ;
        for(int S = 0 ;S < (1<<n) ; ++S)
          for(int i = 0 ;i < n ; ++i)
             vis[i][S] = INF ;
        for(int i = 0 ;i < m ; ++i)
        {
            scanf("%d%d%d%d%d" ,&u ,&v ,&t ,&c1 ,&c2) ;
            u-- ; v-- ; t-- ;
            if(mp[u][v][t].c1 != -1)  // 防止重边(本题不知是否存在)
                    mp[u][v][t].c1 = min(mp[u][v][t].c1 ,c1) ;
            else    mp[u][v][t].c1 = c1 ;
            if(mp[u][v][t].c2 != -1)
                  mp[u][v][t].c2 = min(mp[u][v][t].c2 ,c2) ;
            else  mp[u][v][t].c2 = c2 ;
        }
        int mx = bfs(0) ;
        if(mx != INF)
                cout<<mx<<endl ;
        else    cout<<"impossible"<<endl ;
    }
    return 0 ;
}

版权声明:本文博客原创文章。博客,未经同意,不得转载。

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 卡尔曼滤波 — 从推导到应用(一)「建议收藏」

    卡尔曼滤波 — 从推导到应用(一)「建议收藏」前言卡尔曼滤波器是在估计线性系统状态的过程中,以最小均方差为目的而推导出的几个递推数学等式,也可以从贝叶斯推断的角度来推导。本文将分为两部分:第一部分,结合例子,从最小均方差的角度,直观地介绍卡尔曼滤波的原理,并给出较为详细的数学推导。第二部分,通过两个例子给出卡尔曼滤波的实际应用。其中将详细介绍一个匀加速模型,并直观的对比系统状态模型的建立对滤波的影响。

    2022年6月17日
    35
  • ELK日志分析系统&Sentil插件邮件报警

    ELK日志分析系统&Sentil插件邮件报警

    2021年5月29日
    133
  • Django(64)频率认证源码分析与自定义频率认证「建议收藏」

    Django(64)频率认证源码分析与自定义频率认证「建议收藏」前言有时候我们发送手机验证码,会发现1分钟只能发送1次,这是做了频率限制,限制的时间次数,都由开发者自己决定频率认证源码分析defcheck_throttles(self,request):

    2022年8月7日
    2
  • html中滚动条的代码是什么?如何设置html滚动条?

    html中滚动条的代码是什么?如何设置html滚动条?本篇文章主要介绍了关于 html 中的滚动条的代码 还有关于 html 滚动条代码 marquee 标签属性的用法 具体的让我们一起来看这篇文章吧首先我们介绍 html 中的滚动条代码 今天我们介绍这个 html 滚动条标签是 marquee marquee 标签 它是成对出现的标签 首标签 marquee 和尾标签 marquee 之间的内容就是滚动内容 marquee 标签的属性主要有 behavior bgcolor direction width height marquee marquee

    2025年7月7日
    0
  • 波束形成的一点思考[通俗易懂]

    波束形成的一点思考[通俗易懂]1)波束形成,就是空域滤波。N个阵元,在某一时刻使用FPGA同时采样,得到同一时刻的各个通道的一个采样,就如同拍照一样,同一时刻的各个通道数据得到。  波束形成,则是空域滤波,与时域滤波相比较,是时间域序列,进行滤波,滤波系数h(n),采样序列不断输入与滤波系数卷积计算,得到响应输出;  而波束形成,则是针对某一时刻,不同阵元,通过一个空域滤波系数,得到多少个波束输出;空域滤波系数,一

    2022年6月23日
    24
  • mac时间机器删除旧备份

    mac时间机器删除旧备份

    2021年5月14日
    111

发表回复

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

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