广度优先算法的Java实现

广度优先算法的Java实现

运行结果:

		1
		2
		3
		4
		5
		6
		7
		8

1.测试类

package suanfa;

import java.util.LinkedList;

public class excrise_BfS {

	public static void main(String[] args) {
		findBFS fb = new findBFS();
		int[] nodes = {1,2,3,4,5,6,7,8} ;
		fb.iniAll(8, 9, nodes);
		fb.iniEdges(1, 2, 1);
		fb.iniEdges(1, 3, 1);
		fb.iniEdges(2, 4, 1);
		fb.iniEdges(2, 5, 1);
		fb.iniEdges(4, 8, 1);
		fb.iniEdges(5, 8, 1);
		fb.iniEdges(3, 6, 1);
		fb.iniEdges(3, 7, 1);
		fb.iniEdges(6, 7, 1);
		fb.startBFS(1);
	}

}

2.实现类

class findBFS{
	int numOfNodes;
	int numOfEdges;
	int[] nodes;
	int[][] edges;
	boolean[] isVisited ;
	//初始化边数
	public void iniEdges(int a ,int b ,int weight) {
		edges[a][b] = weight;
	}
	//初始化成员变量
	public void iniAll(int numNode,int numEdge,int[] nodes) {
		numOfNodes = numNode;
		numOfEdges = numEdge;
		this.nodes = nodes;
		edges = new int[numNode + 1][numNode + 1];
		isVisited = new boolean[numNode + 1];
	}
	private void openBFS(int nodes) {
		//初始化队列que
		LinkedList<Integer> que = new LinkedList<>();
		que.addLast(nodes);
		isVisited[nodes] = true;
		
		//核心函数,按BFS算法遍历节点
		while(!que.isEmpty()) {
			System.out.println(nodes);
			que.removeFirst();
			int n = 0;
			while(n != -1) {
				n = findNextneiberhood(n,nodes);
				if (n != -1 && !isVisited[n] ) {
					que.addLast(n);
					isVisited[n] = true;
				}
			}
			if (que.isEmpty()) {
				return;
			}
			nodes = que.getFirst();
		}
	}
	//找到某节点的所有下一层节点
	private int findNextneiberhood(int i, int nodes2) {
		for (int j = i + 1; j < edges.length; j++) {
			if(edges[nodes2][j] > 0) 
				return j;
		}
		return -1;
	}
	//对外提供访问 -——start函数
	public void startBFS(int n) {
		openBFS(n);
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值