java@ 利用ArrayList实现dijkstra算法以及topological 排序算法(java.util.ArrayList)
package dataStructure; import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;
import java.io.*; class node {
int to, dist;
node(int t, int d) {
to = t;
dist = d;
}
} public class Graph { public static void dfs(ArrayList<ArrayList<node> > map, int v, boolean[] vis) {
vis[v] = true;
System.out.print(v + " "); ArrayList<node> rhs = map.get(v);
for(int i=; i<rhs.size(); ++i) {
int nv = rhs.get(i).to;
if(!vis[nv]) dfs(map, nv, vis);
}
} public static void bfs(ArrayList<ArrayList<node> > map, int v) {
boolean[] color = new boolean[map.size()];
LinkedList<Integer> Q = new LinkedList<Integer> (); color[v] = true;
Q.push(v);
int d = ;
System.out.print(v + "(" + d +") "); while(!Q.isEmpty()) {
int top = Q.peek();
Q.pop();
++d; for(node nc: map.get(top)) {
if(!color[nc.to]) {
color[nc.to] = true;
Q.push(nc.to);
System.out.print(nc.to + "(" + d +") ");
}
}
} } public static void caseInit(ArrayList<ArrayList<node> > map) {
addEdge(map, , , );
addEdge(map, , , );
addEdge(map, , , );
addEdge(map, , , );
addEdge(map, , , );
addEdge(map, , , );
addEdge(map, , , );
addEdge(map, , , );
addEdge(map, , , );
addEdge(map, , , );
addEdge(map, , , );
} public static void customize(ArrayList<ArrayList<node> > map) {
Scanner input = new Scanner(System.in);
while(true) {
int v = input.nextInt();
if(v == -) break; int w = input.nextInt(), d = input.nextInt();
addEdge(map, v, w, d);
}
input.close();
} public static void addEdge(ArrayList<ArrayList<node> > map, int from, int to, int dist) {
if(from < || from >= map.size() || to < || to >= map.size()) return; ArrayList<node> rhs = map.get(from);
rhs.add(new node(to, dist)); //ArrayList<node> rhs2 = map.get(to);
//rhs2.add(new node(from, dist));
} public static int[] dijkstra(ArrayList<ArrayList<node> > map, int v) {
int[] min_dis = new int[map.size()];
for(int i=; i<min_dis.length; ++i) min_dis[i] = Integer.MAX_VALUE;
for(int i=; i<map.get(v).size(); ++i) {
min_dis[map.get(v).get(i).to] = map.get(v).get(i).dist;
} boolean[] vis = new boolean[map.size()]; min_dis[v] = ;
vis[v] = true;
ArrayList<node> rhs = map.get(v); for(int i=; i<map.size(); ++i) { int Min = Integer.MAX_VALUE, Minj = v;
for(int j=; j<map.size(); ++j) {
if(!vis[j] && min_dis[j] < Min) {
Min = min_dis[j];
Minj = j;
}
} vis[Minj] = true;
ArrayList<node> tmp = map.get(Minj); for(int k=; k<tmp.size(); ++k) {
if(!vis[tmp.get(k).to] && min_dis[Minj] + tmp.get(k).dist < min_dis[tmp.get(k).to]) {
min_dis[tmp.get(k).to] = min_dis[Minj] + tmp.get(k).dist;
}
}
}
return min_dis;
} public static void topologicalSort(ArrayList<ArrayList<node> > map) {
int[] ind = new int[map.size()];
for(int i=; i<map.size(); ++i) {
for(node nc: map.get(i)) {
++ind[nc.to];
}
} LinkedList<Integer> Q = new LinkedList<Integer> ();
for(int i=; i<map.size(); ++i) {
if(ind[i] == ) {
Q.addLast(i);
//System.out.print(i + " ");
}
} while(!Q.isEmpty()) {
int top = Q.peek();
System.out.print(top + " ");
Q.poll();
for(node nc: map.get(top)) {
--ind[nc.to];
if(ind[nc.to] == ) Q.addLast(nc.to);
}
} }
public static void main(String[] args) {
ArrayList<ArrayList<node> > map = new ArrayList<ArrayList<node> > (); for(int i=; i<; ++i) {
ArrayList<node> row = new ArrayList<node> ();
map.add(row);
}
caseInit(map); int[] min_dis = dijkstra(map, );
//for(int i=0; i<min_dis.length; ++i) System.out.print(min_dis[i] + " "); //bfs(map, 0); topologicalSort(map);
} }
java@ 利用ArrayList实现dijkstra算法以及topological 排序算法(java.util.ArrayList)的更多相关文章
- Java基础语法(8)-数组中的常见排序算法
title: Java基础语法(8)-数组中的常见排序算法 blog: CSDN data: Java学习路线及视频 1.基本概念 排序: 是计算机程序设计中的一项重要操作,其功能是指一个数据元素集合 ...
- 插入排序算法--直接插入算法,折半排序算法,希尔排序算法(C#实现)
插入排序算法主要分为:直接插入算法,折半排序算法(二分插入算法),希尔排序算法,后两种是直接插入算法的改良.因此直接插入算法是基础,这里先进行直接插入算法的分析与编码. 直接插入算法的排序思想:假设有 ...
- Java程序员必须掌握的8大排序算法
分类: 1)插入排序(直接插入排序.希尔排序)2)交换排序(冒泡排序.快速排序)3)选择排序(直接选择排序.堆排序)4)归并排序5)分配排序(基数排序) 所需辅助空间最多:归并排序所需辅助空间最少:堆 ...
- Java程序员必知的8大排序算法
8种排序之间的关系 直接插入排序 (1)基本思想:在要排序的一组数中,假设前面(n-1)[n>=2] 个数已经是排 好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数 也是排好顺序的.如 ...
- JAVA 基础编程练习题28 【程序 28 排序算法】
28 [程序 28 排序算法] 题目:对 10 个数进行排序 程序分析:可以利用选择法,即从后 9 个比较过程中,选择一个最小的与第一个元素交换, 下次类推,即 用第二个元素与后 8 个进行比较,并进 ...
- 学习Java绝对要懂的,Java编程中最常用的几种排序算法!
今天给大家分享一下Java中几种常见的排序算法的Java代码 推荐一下我的Java学习羊君前616,中959,最后444.把数字串联起来! ,群里有免费的学习视频和项目给大家练手.大神有空时也 ...
- java利用自定义类型对树形数据类型进行排序
前言 为什么集合在存自定义类型时需要重写equals和hashCode? 1.先说List集合 List集合在存数据时是可以重复的但是 当我们需要判断一个对象是否在集合中存在时这样就有问题了! 因为我 ...
- java 合并排序算法、冒泡排序算法、选择排序算法、插入排序算法、快速排序算法的描述
算法是在有限步骤内求解某一问题所使用的一组定义明确的规则.通俗点说,就是计算机解题的过程.在这个过程中,无论是形成解题思路还是编写程序,都是在实施某种算法.前者是推理实现的算法,后者是操作实现的算法. ...
- JAVA SE回顾及思考(3)——排序算法
排序的算法是很多公司的笔试和面试题,个人感觉Java中其实无需使用这些排序方法,因为Java中已经为我们提供了很方便效率很高的sort()方法.但是不使用不能代表不需要学习这些算法,也不是仅仅为了面试 ...
随机推荐
- 1027-Quicksum
描述 A checksum is an algorithm that scans a packet of data and returns a single number. The idea is t ...
- POJ 3761 Bubble Sort(乘方取模)
点我看题目 题意 : 冒泡排序的原理众所周知,需要扫描很多遍.而现在是求1到n的各种排列中,需要扫描k遍就变为有序的数列的个数,结果模20100713,当然了,只要数列有序就扫描结束,不需要像真正的冒 ...
- linux下mysql修改数据库账户root密码
#先停止mysql,再运行下一句 $ mysqld_safe --user=mysql --skip-grant-tables --skip-networking & $ mysql -u r ...
- 手机金属外壳加工工艺:铸造、锻造、冲压、CNC
现如今金属手机成为行业的热点,在消费电子产品中应用越来越广,本文详细介绍几种金属加工工艺及相关产品应用. 1.CNC+阳极:iPhone 5/6, HTC M7 2.锻造+CNC:华为P8,HTC M ...
- 使用IntelliJ Idea创建Spring MVC项目
- Windbg:如何给字符串下条件断点
因为Windgb支持MASM语法,字符串的比较方法有$scmp和$sicmp.用法和c中的字符串比较方法一致.在需要比较字符串成员变量的时候,遇到了点问题.因为字符串成员变量无法直接获取字符串内容.p ...
- raid之理解
RAID方案有两种,一种是硬件RAID解决方案,一种是软RAID解决方案. 硬件RAID解决方案 1.RAID 0 RAID 0是最早出现的RAID模式,即Data Stripping数据分条技术.R ...
- (转)Redis与Memcached的区别
如果简单地比较Redis与Memcached的区别,大多数都会得到以下观点: 1 Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,hash等数据结构的存储. 2 Redis支持 ...
- 关于SQL Server 数据库的备份
备份 第一 :选择数据库右键任务,然后直接选择分离,再选择删除和更新上打勾,之后到sqlsever安装目录下查看,会生成xx.mdf和xx.ldf两个文件(既有表结构又有数据). 第二:可以选择备份, ...
- [转载]Java的内存回收机制
转自:http://www.admin10000.com/document/1671.html 在Java中,它的内存管理包括两方面:内存分配(创建Java对象的时候)和内存回收,这两方面工作都是由J ...