选择V-S中的点加入S时用了贪心思想,即求d[]中legth最小且未被标记(未加入加入S)的点。

一点都没优化的实现:

 import java.lang.reflect.Array;

 /**
* Created by yueli on 2018/10/14.
*/
public class Dijkstra {
boolean mark[]=new boolean[5];
int v[][]={{0,10,-1,30,100}, {-1,0,50,-1,-1},{-1,-1,0,-1,10},{-1,10,20,0,60},{-1,-1,-1,-1,0}};
class Dist{
public int pre;
public int length;
public Dist(){}
public Dist(int pre,int length){
this.pre=pre;
this.length=length;
}
}
int maxInt=0xfffffff;
public Dist D[]=new Dist[5];
boolean AllMarked(){
for(int i=0;i<mark.length;i++)
if(!mark[i])
return false;
return true;
}
void dijkstra(final int s){
for(int i=0;i<5;i++) {
D[i]=new Dist();
D[i].pre = s;
D[i].length = v[s][i];
mark[i]=false;
}
int u=s;
mark[s]=true;
while (!AllMarked()){
int min=maxInt;
for(int i=0;i<5;i++)
if(!mark[i]&&D[i].length>0&&D[i].length<min){
min=D[i].length;
u=i;
}
System.out.print("{+"+u+"} ");
printD();
if(min==maxInt)break;
mark[u]=true;
for(int i=0;i<5;i++)
if(v[u][i]>0&&(D[i].length>D[u].length+v[u][i]||D[i].length<0)){
D[i].length=D[u].length+v[u][i];
D[i].pre=u;
}
}
}
void printD(){
for(int i=0;i<5;i++){
System.out.print("pre:"+D[i].pre+" length:"+D[i].length+" ");
}
System.out.println();
}
void printV(){
for(int i=0;i<5;i++) {
for (int j = 0; j < 5; j++)
System.out.print(v[i][j]+" ");
System.out.println();
}
}
public static void main(String[] args) {
Dijkstra dijkstra=new Dijkstra();
dijkstra.printV();
dijkstra.dijkstra(0);
}
}
 void dijkstra(final int s){
for(int i=0;i<5;i++) {
D[i]=new Dist();
D[i].pre = s;
D[i].length = v[s][i];
mark[i]=false;
}
int u=s;
mark[s]=true;
while (!AllMarked()){
int min=maxInt;
for(int i=0;i<5;i++)
if(!mark[i]&&D[i].length>0&&D[i].length<min){
min=D[i].length;
u=i;
}
System.out.print("{+"+u+"} ");
printD();
if(min==maxInt)break;
mark[u]=true;
for(int i=0;i<5;i++)
if(v[u][i]>0&&(D[i].length>D[u].length+v[u][i]||D[i].length<0)){
D[i].length=D[u].length+v[u][i];
D[i].pre=u;
}
}
}
0 10 -1 30 100
-1 0 50 -1 -1
-1 -1 0 -1 10
-1 10 20 0 60
-1 -1 -1 -1 0
{+1} pre:0 length:0 pre:0 length:10 pre:0 length:-1 pre:0 length:30 pre:0 length:100
{+3} pre:0 length:0 pre:0 length:10 pre:1 length:60 pre:0 length:30 pre:0 length:100
{+2} pre:0 length:0 pre:0 length:10 pre:3 length:50 pre:0 length:30 pre:3 length:90
{+4} pre:0 length:0 pre:0 length:10 pre:3 length:50 pre:0 length:30 pre:2 length:60 Process finished with exit code 0
#include <iostream>
#include<Queue>
using namespace std;
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
bool allMarked(bool *mark,const int n){
for(int i=;i<n;i++){
if(!mark[i]){
return false;
}
}
return true;
}
int getFirstUnmarked(bool* mark,const int n){
for(int i=;i<n;i++){
if(!mark[i]){
return i;
}
}
return -;
}
void BFS(bool d[][],const int n,int s){
queue<int>q;
bool *mark=new bool[n];
q.push(s);mark[s]=;
while(!q.empty()||!allMarked(mark,n)){
while(!q.empty()){
s=q.front();
q.pop();
cout<<s<<" ";
for(int i=;i<n;i++){
if(!mark[i]&&d[s][i]){
q.push(i);
mark[i]=;
}
}
}
if(!allMarked(mark,n)){
q.push(getFirstUnmarked(mark,n));
}
}
}
void DFS(bool d[][],const int n,int s){
queue<int>q;
bool *mark=new bool[n];
}
int main(int argc, char *argv[]) {
bool v[][]={
{,,,,},
{,,,,},
{,,,,},
{,,,,},
{,,,,}};
BFS(v,,);
return ;
}

【图论算法】Dijstra&BFS的更多相关文章

  1. 图论算法-最小费用最大流模板【EK;Dinic】

    图论算法-最小费用最大流模板[EK;Dinic] EK模板 const int inf=1000000000; int n,m,s,t; struct node{int v,w,c;}; vector ...

  2. 图论算法-网络最大流【EK;Dinic】

    图论算法-网络最大流模板[EK;Dinic] EK模板 每次找出增广后残量网络中的最小残量增加流量 const int inf=1e9; int n,m,s,t; struct node{int v, ...

  3. 【WIP_S9】图论算法

    创建: 2018/06/01 图的概念 有向边 有向图 无向边 无向图 点的次数: 点连接的边的数量 闭路: 起点和重点一样 连接图: 任意两点之间都可到达 无闭路有向图: 没有闭路的有向图 森林: ...

  4. NOIp 图论算法专题总结 (1):最短路、最小生成树、最近公共祖先

    系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 最短路 Floyd 基本思路:枚举所有点与点的中点,如果从中点走最短,更新两点间 ...

  5. NOIp 图论算法专题总结 (3):网络流 & 二分图 简明讲义

    系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 网络流 概念 1 容量网络(capacity network)是一个有向图,图的 ...

  6. 图论算法-Tarjan模板 【缩点;割顶;双连通分量】

    图论算法-Tarjan模板 [缩点:割顶:双连通分量] 为小伙伴们总结的Tarjan三大算法 Tarjan缩点(求强连通分量) int n; int low[100010],dfn[100010]; ...

  7. tarjan图论算法

    tarjan图论算法 标签: tarjan 图论 模板 洛谷P3387 [模板]缩点 算法:Tarjan有向图强连通分量+缩点+DAGdp 代码: #include <cstdio> #i ...

  8. [算法模版]Tarjan爷爷的几种图论算法

    [算法模版]Tarjan爷爷的几种图论算法 前言 Tarjan爷爷发明了很多图论算法,这些图论算法有很多相似之处(其中一个就是我都不会).这里会对这三种算法进行简单介绍. 定义 强连通(strongl ...

  9. NOIp 图论算法专题总结 (2)

    系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 树链剖分 https://oi-wiki.org/graph/heavy-lig ...

  10. 图论算法(一)存图与STL第六弹——vector容器

    图论算法(一)存图 我发现我的博客阅读量贼低,问小伙伴们,ta们都说这些博客太长了QAQ! 今天来个短亿点的(也短不了多少……) 进入正题,图论究竟是什么? 图论就是给你一张图,让你在这张图上进行各种 ...

随机推荐

  1. Node.js NPM 介绍

    章节 Node.js NPM 介绍 Node.js NPM 作用 Node.js NPM 包(Package) Node.js NPM 管理包 Node.js NPM Package.json NPM ...

  2. kafka源码系列之mysql数据增量同步到kafka

    一,架构介绍 生产中由于历史原因web后端,mysql集群,kafka集群(或者其它消息队列)会存在一下三种结构. 1,数据先入mysql集群,再入kafka 数据入mysql集群是不可更改的,如何再 ...

  3. UVA - 12186 Another Crisis(工人的请愿书)(树形dp)

    题意:某公司有1个老板和n(n<=105)个员工组成树状结构,除了老板之外每个员工都有唯一的直属上司.老板的编号为0,员工编号为1~n.无下属的员工(叶子)打算签署一项请愿书递给老板,但不能跨级 ...

  4. 12 —— node 获取文件属性 —— 利用 自调用 闭包函数 解决 i 丢失的问题

    闭包的作用 : 保存变量 一,i 丢失的案例 var arr = ['node','vue','mysql'] for(var i=0;i<arr.length;i++){ setTimeout ...

  5. android:padding和android:margin的区别 android:gravity和 android:layout_gravity 区别

    Android的Margin和Padding跟Html的是一样的.如下图所示:橙色边框(一个RelativeLayout或者LinearLayout)为例,最外层灰色为屏幕边框,黄色部分为Paddin ...

  6. BZOJ:2244: [SDOI2011]拦截导弹

    问题: printf("%.5f ",0):为什么错了? 注意: 初始值很重要 题解: 三维偏序问题: 记录从前往后最长上升子序列长度pref,条数preg 从后往前suff,su ...

  7. DFS+BFS(广度优先搜索弥补深度优先搜索遍历漏洞求合格条件总数)--09--DFS+BFS--蓝桥杯剪邮票

    题目描述 如下图, 有12张连在一起的12生肖的邮票.现在你要从中剪下5张来,要求必须是连着的.(仅仅连接一个角不算相连)  比如,下面两张图中,粉红色所示部分就是合格的剪取.  请你计算,一共有多少 ...

  8. python期末复习—列表

    列表:列表元素需用逗号分隔,放在方括号里,如:list=['Q',15];元素类型可以是数字,单个字符,字符串,列表.字符串和字符需要用单引号引起来. 访问列表:print(列表名[0])访问第一个元 ...

  9. 理解Production- Ready特性

    1.外部配置(externalized configuration) 1).基于环境变量的配置 2).基于YAML的配置 3).默认配置值 2.健康检查(health checks) 1).它是否有一 ...

  10. ArchLinux安装(BIOS)

    ArchLinux安装(BIOS) 说在前头:在经历过无数次的失败尝试过后总结出的可用的安装过程(比官方的简单一点) 官方安装指导 一.连接网络 1.连接 # wifi-menu 2.检查是否联通 ( ...