最短路问题之dijikstra算法

cpp 复制代码
//根据bfs修改而来
#include<stdio.h>
#include<stdlib.h>
typedef struct queue {
    int data;
    struct queue* next;
}queue, * linklist;
float dist_list[9];
//出发点为0
int forward_point_list[9] = { -1 };
linklist front = NULL;
linklist rear = NULL;
float map_frame[9][9] = { 0,4,-1,-1,-1,-1,-1,8,-1,
                       4,0,8,-1,-1,-1,-1,11,-1,
                       -1,8,0,7,-1,4,-1,-1,2,
                       -1,-1,7,0,9,14,-1,-1,-1,
                       -1,-1,-1,9,0,10,-1,-1,-1,
                       -1,-1,4,14,10,0,2,-1,-1,
                       -1,-1,-1,-1,-1,2,0,1,6,
                       8,11,-1,-1,-1,-1,1,0,7,
                       -1,-1,2,-1,-1,-1,6,7,0 };
void enqueue(int v) {
    linklist node = (linklist)malloc(sizeof(queue));
    node->data = v;
    node->next = NULL;
    if (!front) {
        front = rear = node;
    }
    else {
        rear->next = node;
        rear = node;
    }
}
int dequeue() {
    if (!front) {
        return -1;
    }
    linklist tmp = front;
    int v = front->data;
    front = front->next;
    if (!front) {
        rear = NULL;
    }
    free(tmp);
    return v;
}
bool isEmpty() {
    return front == NULL;
}
void DJSTRA(int v,int search) {
    enqueue(v);
    dist_list[v] = map_frame[v][v];
    forward_point_list[v] = v;
    while (isEmpty() == false) {
        v = dequeue();
        for (int i = 0; i < 9; i++) {
            if (map_frame[v][i] > 0) {
                if (dist_list[i] > dist_list[v] + map_frame[v][i]) {
                    dist_list[i] = dist_list[v] + map_frame[v][i];
                    forward_point_list[i] = v;
                    enqueue(i);
                }
            }
        }
    }
    for (int j = 0; j < 9; j++) {
        printf("%f\n", dist_list[j]);
    }
    while (search != 0) {
        printf("点%d由",search);
        search = forward_point_list[search];
        printf("%d而来\n",search);        
    }
 }
int main() {
    for (int j = 0; j < 9; j++) {
        dist_list[j] = 100.0;
    }
    DJSTRA(0,4);
    return 0;
}

相关推荐
姜西西_8 分钟前
递归 算法专题
算法·深度优先
nurupo1239 分钟前
C++学习路线(二十五)
c++·学习·算法
wrx繁星点点35 分钟前
原型模式:高效的对象克隆解决方案
数据结构·spring·spring cloud·java-ee·maven·intellij-idea·原型模式
LNTON羚通1 小时前
算法定制LiteAIServer视频智能分析平台裸土检测技术实现、应用场景与优势概览
大数据·算法·目标检测·音视频·监控
书鸢12362 小时前
力扣每日一题合集
java·算法·leetcode
何事驚慌2 小时前
2024/10/30 数据结构大题打卡
数据结构
我不会JAVA!3 小时前
排序算法(3) C++
c++·算法·排序算法
Willliam_william3 小时前
SystemC学习(3)— APB_SRAM的建模与测试
学习·算法
Gui林3 小时前
【GL07】C语言要点
c语言·算法
爱编程— 的小李4 小时前
有序序列合并(c语言)
c语言·算法