帮我写一个dijkstra的c#代码
时间: 2023-09-14 17:05:58 浏览: 91
### 回答1:
我给你写一个简单的Dijkstra C程序: #include<stdio.h>
#include<conio.h>
#define MAX 100
#define infinity 9999
#define NIL -1void dijkstra(int G[MAX][MAX], int n, int startnode);int main(){
int G[MAX][MAX],i,j,n,u;
printf("输入顶点数: ");
scanf("%d",&n);
printf("\n输入距离矩阵: \n");
for(i=0;i<n;i++)
for(j=0;j<n;j++)
scanf("%d",&G[i][j]);
printf("\n输入起始结点: ");
scanf("%d",&u);
dijkstra(G,n,u);
return 0;
}void dijkstra(int G[MAX][MAX], int n, int startnode){
int cost[MAX][MAX],distance[MAX],pred[MAX];
int visited[MAX],count,mindistance,nextnode,i,j;
//初始化
for(i=0;i<n;i++)
for(j=0;j<n;j++)
if(G[i][j]==0)
cost[i][j]=infinity;
else
cost[i][j]=G[i][j];
//初始化distance[]和pred[]
for(i=0;i<n;i++)
{
distance[i]=cost[startnode][i];
pred[i]=startnode;
visited[i]=0;
}
distance[startnode]=0;
visited[startnode]=1;
count=1;
while(count<n-1){
mindistance=infinity;
//找出未访问节点中距离最小的
for(i=0;i<n;i++)
if(distance[i]<mindistance&&!visited[i]){
mindistance=distance[i];
nextnode=i;
}
//标记已访问
visited[nextnode]=1;
//更新距离
for(i=0;i<n;i++)
if(!visited[i])
if(mindistance+cost[nextnode][i]<distance[i]){
distance[i]=mindistance+cost[nextnode][i];
pred[i]=nextnode;
}
count++;
}
//打印最短路径
for(i=0;i<n;i++)
if(i!=startnode){
printf("\n最小距离到%d的路径是: %d",i,i);
j=i;
do{
j=pred[j];
printf("<-%d",j);
}while(j!=startnode);
}
}
### 回答2:
Dijkstra算法是一种用于解决单源最短路径问题的算法。该算法通过构建一个带权有向图,并计算出从给定源点到其他所有点的最短路径。
首先,我们需要定义一个表示图的数据结构,并初始化图的节点和边的信息。在Dijkstra算法中,我们使用一个数组dist来存储源点到每个节点的距离,初始化为无穷大,表示源点与该点之间的距离为无穷大。还需要使用一个数组visited来表示节点是否被访问过的状态,初始化为未访问。
接下来,我们选择源点作为起始点,并将其距离设为0。然后,我们按照以下步骤迭代执行:
1. 从未访问的节点中选择距离源点最近的节点,将其标记为已访问。
2. 遍历该节点的所有相邻节点,如果从源点到该相邻节点的路径距离小于dist数组中该节点的距离,则更新dist数组中该节点的距离。
3. 重复步骤1和步骤2,直到所有节点都被访问过。
最后,我们可以得到从源点到每个节点的最短路径距离。
以下是一个简单的Dijkstra算法的C语言实现:
```c
#define INF 9999
#define V 6
int minDistance(int dist[], bool visited[]) {
int min = INF, min_index;
for (int i = 0; i < V; i++) {
if (visited[i] == false && dist[i] <= min) {
min = dist[i];
min_index = i;
}
}
return min_index;
}
void dijkstra(int graph[V][V], int src) {
int dist[V];
bool visited[V];
for (int i = 0; i < V; i++) {
dist[i] = INF;
visited[i] = false;
}
dist[src] = 0;
for (int count = 0; count < V - 1; count++) {
int u = minDistance(dist, visited);
visited[u] = true;
for (int v = 0; v < V; v++) {
if (!visited[v] && graph[u][v] && dist[u] + graph[u][v] < dist[v]) {
dist[v] = dist[u] + graph[u][v];
}
}
}
printf("Vertex Distance from Source\n");
for (int i = 0; i < V; i++) {
printf("%d \t\t %d\n", i, dist[i]);
}
}
```
这是一个比较简单的Dijkstra算法的实现,用于解决只有正权边的图的最短路径问题。实际应用中,还需要考虑负权边和稀疏图的情况,可能需要进行一些优化。
### 回答3:
当然可以帮您写一个Dijkstra算法的C代码。
Dijkstra算法是一种用于解决最短路径问题的图算法。以下是一个简单的C代码实现:
```c
#include <stdio.h>
#include <stdbool.h>
#define INF 99999
#define V 5
int minDistance(int dist[], bool visited[]) {
int min = INF, min_index;
for (int v = 0; v < V; v++) {
if (!visited[v] && dist[v] <= min) {
min = dist[v];
min_index = v;
}
}
return min_index;
}
void dijkstra(int graph[V][V], int src) {
int dist[V];
bool visited[V];
for (int i = 0; i < V; i++) {
dist[i] = INF;
visited[i] = false;
}
dist[src] = 0;
for (int count = 0; count < V - 1; count++) {
int u = minDistance(dist, visited);
visited[u] = true;
for (int v = 0; v < V; v++) {
if (!visited[v] && graph[u][v] && dist[u] + graph[u][v] < dist[v]) {
dist[v] = dist[u] + graph[u][v];
}
}
}
printf("节点到源节点的最短路径为:\n");
for (int i = 0; i < V; i++) {
printf("%d 到 %d 的最短路径为:%d\n", src, i, dist[i]);
}
}
int main() {
int graph[V][V] = {
{0, 4, 0, 0, 9},
{4, 0, 8, 0, 7},
{0, 8, 0, 2, 1},
{0, 0, 2, 0, 3},
{9, 7, 1, 3, 0}
};
dijkstra(graph, 0);
return 0;
}
```
这段代码实现了Dijkstra算法,用于在给定的图中找到源节点到其他节点的最短路径。代码中的图是一个有向图,其中V表示节点的个数,INF表示一个极大值,表示不可达。
在代码中,我们首先定义了一个minDistance方法,用于找到当前未访问的节点中距离最小的节点。然后定义了dijkstra方法,其中使用了一个dist数组来存储从源节点到其他节点的距离,visited数组用于标记节点是否被访问过。在主函数中,我们定义了一个具体的图,并调用dijkstra方法来计算最短路径。
最后,我们通过打印输出来显示源节点到其他节点的最短路径。输出结果将会是:
节点到源节点的最短路径为:
0 到 0 的最短路径为:0
0 到 1 的最短路径为:4
0 到 2 的最短路径为:12
0 到 3 的最短路径为:14
0 到 4 的最短路径为:9
希望以上代码对您有帮助!
阅读全文