当前位置: 首页 > article >正文

【C语言算法刷题】第2题 图论 dijkastra

题目描述

一个局域网内有很多台电脑,分别标注为 0 ~ N-1 的数字。相连接的电脑距离不一样,所以感染时间不一样,感染时间用 t 表示

其中网络内一台电脑被病毒感染,求其感染网络内所有的电脑最少需要多长时间。如果最后有电脑不会感染,则返回-1。

给定一个数组 times 表示一台电脑把相邻电脑感染所用的时间。

如图:path[i] = {i, j, t} 表示:电脑 i->j,电脑 i 上的病毒感染 j,需要时间 t。

输入输出描述

输入

4
3
2 1 1
2 3 1
3 4 1
2

输出

2

 解释

第一个参数:局域网内电脑个数N,1 ≤ N ≤ 200;

第二个参数:总共多少条网络连接

第三个 2 1 1 表示2->1时间为1

第六行:表示病毒最开始所在电脑号2

数据预处理

main(){
 
 int n;
 scanf("%d",&n);/*输入顶点的个数*/
 
 /*初始化邻接矩阵*/
 int matrix[n+1][n+1];
 for(int i=0;i<=n;i++){
    for(int j=0;j<=n;j++){
        matrix[i][j]=-1;/*全部是离散的点*/
    }
 }
 
 /*输入边的条数m*/
 int m;
 scanf("%d",&m);
 
 /*输入邻接矩阵的边权重*/
 for(int i=0;i<m;i++){
    int u,v,w;
    scanf("%d %d %d",&u,&v,&w);
    matrix[u][v]=w;
 }
 
 /*输入源点src*/
 int src;
 scanf("%d",&src);
    
    
}

必要的数据结构 

 /*是否已经被访问*/
 bool visited[n+1];
 /*用来存储src到每个顶点的最短距离*/
 int dist[n+1];
 /*初始化*/
 for(int i=1;i<=n;i++){
    visited[i]=FALSE;
    dist[i]=INT_MAX;/*距离初始化为正无穷*/
 }
 dist[src]=0;
 
 /*二维数组用于记录每个顶点的编号和到源点距离*/
 int pq[MAX_SIZE][2];
 int pq_size=0;
 pq[pq_size][0]=src;
 pq[pq_size][1]=dist[src];
 pq_size++;
  

dijkastra解决单源最短路径的主体代码 

    /*while队不空(数组pq[]实现的顺序队列)*/
    while(pq_size>0){
        /*每轮找dist最小的,出队列*/
        int u=pq[--pq_size][0];
        if(visited[u]==TRUE) continue;
        visited[u]=TRUE;/*设置当前选择的结点为已经访问*/
        
        /*对u的所有邻居*/
        for(int v=1;v<=n;v++){
            int w=matrix[u][v];
            if(w!=-1){
                int newDist=dist[u]+w;
                if(newDist<dist[v]){
                    dist[v]=newDist;
                    pq[pq_size][0]=v;/*邻居v入队列pq[]*/
                    pq[pq_size][1]=dist[v];
                    pq_size++;
                    /*按照路径最短进行降序排序*/
                    qsort(pq,pq_size,sizeof(pq[0]),cmp);
                }
            }
        }       
    }

输出答案

    int sum=0;
    for(int i=1;i<=n;i++){
        sum+=dist[i];
    }
    printf("%d\n",sum);
    return 0;
   
}

知识补充BFS和Dijkastra

 


http://www.kler.cn/a/518095.html

相关文章:

  • HTML-新浪新闻-实现标题-样式1
  • 【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.10 文本数据炼金术:从CSV到结构化数组
  • 数据结构与算法再探(六)动态规划
  • MongoDB 备份与恢复综述
  • SYN Flooding的攻击原理
  • Ubuntu20.04 深度学习环境配置(持续完善)
  • PBFT算法
  • ESG报告流程参考
  • 【深度学习】搭建PyTorch神经网络进行气温预测
  • Qt 5.14.2 学习记录 —— 십구 事件
  • 豆包MarsCode 蛇年编程大作战 | 高效开发“蛇年运势预测系统”
  • Effective C++读书笔记——item23(用非成员,非友元函数取代成员函数)
  • Redis实现,分布式Session共享
  • S4 HANA Tax相关的定价过程
  • c#使用log4Net配置日志文件
  • idea maven本地有jar包,但还要从远程下载
  • 使用ArcMap或ArcGIS Pro连接达梦数据库创建空间数据库
  • 为什么redis会开小差?Redis 频繁异常的深度剖析与解决方案
  • 【ARM】解决MDK在打开工程的时候提示CMSIS的版本不对问题
  • kettle从入门到精通 第九十一课 ETL之kettle http接口下载文件流
  • Java设计模式:结构型模式→桥接模式
  • LabVIEW太阳能照明监控系统
  • PCI 总线学习笔记(三)
  • Vue3笔记——(五)路由
  • Kubernetes v1.28.0安装dashboard v2.6.1(k8s图形化操作界面)
  • kettle经验篇:分享两个小白常见问题