Choose the best route

本文深入探讨了如何解决特定场景下的最短路径问题,通过逆向思维从终点到起点寻找路径,特别关注单向路程的处理。文章提供了一个具体实例,展示了如何在存在多个车站的城市交通路线中,为容易晕车的Kiki找到到达朋友家的最快路线。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

One day , Kiki wants to visit one of her friends. As she is liable to carsickness , she wants to arrive at her friend’s home as soon as possible . Now give you a map of the city’s traffic route, and the stations which are near Kiki’s home so that she can take. You may suppose Kiki can change the bus at any station. Please find out the least time Kiki needs to spend. To make it easy, if the city have n bus stations ,the stations will been expressed as an integer 1,2,3…n.

Input

There are several test cases.
Each case begins with three integers n, m and s,(n<1000,m<20000,1=<s<=n) n stands for the number of bus stations in this city and m stands for the number of directed ways between bus stations .(Maybe there are several ways between two bus stations .) s stands for the bus station that near Kiki’s friend’s home.
Then follow m lines ,each line contains three integers p , q , t (0<t<=1000). means from station p to station q there is a way and it will costs t minutes .
Then a line with an integer w(0<w<n), means the number of stations Kiki can take at the beginning. Then follows w integers stands for these stations.

Output

The output contains one line for each data set : the least time Kiki needs to spend ,if it’s impossible to find such a route ,just output “-1”.

Sample Input

5 8 5
1 2 2
1 5 3
1 3 4
2 4 7
2 5 6
2 3 5
3 5 1
4 5 1
2
2 3
4 3 4
1 2 3
1 3 4
2 3 2
1
1

Sample Output

1
-1

这道题是最短路啊,但是你需要从终点向起点走,但是呢路程是单向的,并且你要格外注意这件事,我头铁错了好多次啊,但是也要努力啊!

#include<stdio.h>
#include<string.h>
#include<math.h>
#include<queue>
#include<stack>
#include<algorithm>
#define inf 0x3f3f3f3f
using namespace std;
int a[1111][1111],dis[1111];
bool book[1111];
int n,m,en;
int main()
{
    while(~scanf("%d%d%d",&n,&m,&en))
    {
        int i,j,k,t1,t2,t3,u,v;
        for(i=1;i<=n;i++)
        {
            for(j=1;j<=n;j++)
                if(i==j)
                a[i][j]=0;
            else
                a[i][j]=inf;

        }
        for(i=1;i<=m;i++)
        {
            scanf("%d%d%d",&t1,&t2,&t3);
            if(t3<a[t2][t1])
            {
                a[t2][t1]=t3;
           
            }
        }
        for(i=1;i<=n;i++)
        {
            book[i]=0;
            dis[i]=a[en][i];
        }
        book[en]=1;
        int minn;
        for(i=1;i<=n-1;i++)
        {
            minn=inf;
            for(j=1;j<=n;j++)
            {
                if(!book[j]&&dis[j]<minn)
                {
                    minn=dis[j];
                    u=j;
                }

            }
            book[u]=1;
            for(v=1;v<=n;v++)
            {
                if(!book[v]&&a[u][v]!=inf&&dis[v]>dis[u]+a[u][v])
                    dis[v]=dis[u]+a[u][v];
            }
        }
        int a,x,ans=inf;
        scanf("%d",&a);
        for(i=1;i<=a;i++)
        {
            scanf("%d",&x);
            if(ans>dis[x])
                ans=dis[x];
        }
        if(ans!=inf)
            printf("%d\n",ans);
        else
            printf("-1\n");
    }
    return 0;
}

 

### 计算机网络基础:路由与交换原理及区别 #### 一、路由的概念及其功能 路由器作为一种关键的网络设备,在计算机网络中承担着至关重要的角色。其核心职责在于跨不同网络间的数据包传输,确保数据能够准确无误地从源头抵达目的地,并且在此过程中寻找最优路径来提高效率和可靠性[^2]。 #### 二、交换的概念及其特性 相比之下,交换发生在同一局域网内部的不同节点之间。交换机依据MAC地址表快速查找目标端口并将帧发送出去;这种操作几乎是在硬件层面完成的,因此速度非常快。而且由于采用了全双工通信模式,使得在同一时刻可以实现双向的信息交流而不会发生冲突。 #### 三、两者的主要差异点 - **工作层次**:路由位于OSI七层模型中的第三层&mdash;&mdash;即网络层,处理的是IP地址级别的逻辑寻址问题;而交换则处于第二层数据链路层,关注物理介质上的位流控制以及基于MAC地址的身份识别。 - **覆盖范围**:前者适用于广域网(WAN),后者多见于局域网(LAN)环境内; - **决策机制**:对于路由而言,选择最佳路径涉及到复杂的算法计算(如RIP协议按照定时更新的方式共享邻居间的距离矢量信息),并且可能跨越多个子网边界;相反,简单的查表匹配足以满足大多数情况下交换的需求[^3]。 ```python # Python伪代码展示如何模拟基本的路由选择过程 def choose_best_path(routes): best_route = None lowest_metric = float('inf') for route in routes: if route['metric'] < lowest_metric: lowest_metric = route['metric'] best_route = route return best_route routes_example = [ {'destination': '192.168.1.0/24', 'next_hop': '10.0.0.1', 'metric': 1}, {'destination': '172.16.0.0/16', 'next_hop': '10.0.0.2', 'metric': 5} ] print(choose_best_path(routes_example)) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值