亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? variablegraph.java

?? K-shortest算法實現
?? JAVA
字號:
/*
 *
 * Copyright (c) 2004-2008 Arizona State University.  All rights
 * reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 *
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in
 *    the documentation and/or other materials provided with the
 *    distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY ARIZONA STATE UNIVERSITY ``AS IS'' AND
 * ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL ARIZONA STATE UNIVERSITY
 * NOR ITS EMPLOYEES BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 */

package edu.asu.emit.qyan.alg.model;

import java.util.Collection;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.Vector;

import edu.asu.emit.qyan.alg.control.DijkstraShortestPathAlg;
import edu.asu.emit.qyan.alg.model.abstracts.BaseVertex;

/**
 * @author <a href='mailto:Yan.Qi@asu.edu'>Yan Qi</a>
 * @version $Revision: 431 $
 * @latest $Id: VariableGraph.java 431 2008-07-27 23:35:56Z qyan $
 */
public class VariableGraph extends Graph
{
	Set<Integer> _rem_vertex_id_set = new HashSet<Integer>();
	Set<Pair<Integer, Integer>> _rem_edge_set = new HashSet<Pair<Integer, Integer>>();

	/**
	 * Default constructor
	 * 
	 * @param data_file_name
	 */
	public VariableGraph(String data_file_name)
	{
		super(data_file_name);
	}
	
	/**
	 * Constructor 2
	 * 
	 * @param graph
	 */
	public VariableGraph(Graph graph)
	{
		super(graph);
	}

	/**
	 * Set the set of vertices to be removed from the graph
	 * 
	 * @param _rem_vertex_list
	 */
	public void set_rem_vertex_id_list(Collection<Integer> _rem_vertex_list)
	{
		this._rem_vertex_id_set.addAll(_rem_vertex_list);
	}

	/**
	 * Set the set of edges to be removed from the graph
	 * 
	 * @param _rem_edge_hashcode_set
	 */
	public void set_rem_edge_hashcode_set(Collection<Pair<Integer, Integer>> rem_edge_collection)
	{
		_rem_edge_set.addAll(rem_edge_collection);
	}
	
	/**
	 * Add an edge to the set of removed edges
	 * 
	 * @param edge
	 */
	public void remove_edge(Pair<Integer, Integer> edge)
	{
		_rem_edge_set.add(edge);
	}
	
	/**
	 * Add a vertex to the set of removed vertices
	 * 
	 * @param vertex_id
	 */
	public void remove_vertex(Integer vertex_id)
	{
		_rem_vertex_id_set.add(vertex_id);
	}
	
	public void recover_removed_edges()
	{
		_rem_edge_set.clear();
	}

	public void recover_removed_edge(Pair<Integer, Integer> edge)
	{
		_rem_edge_set.remove(edge);
	}
	
	public void recover_removed_vertices()
	{
		_rem_vertex_id_set.clear();
	}
	
	public void recover_removed_vertex(Integer vertex_id)
	{
		_rem_vertex_id_set.remove(vertex_id);
	}
	
	/**
	 * Return the weight associated with the input edge.
	 * 
	 * @param source
	 * @param sink
	 * @return
	 */
	public double get_edge_weight(BaseVertex source, BaseVertex sink)
	{
		int source_id = source.get_id();
		int sink_id = sink.get_id();
		
		if(_rem_vertex_id_set.contains(source_id) || _rem_vertex_id_set.contains(sink_id) 
				|| _rem_edge_set.contains(new Pair<Integer, Integer>(source_id, sink_id)))
		{
			return Graph.DISCONNECTED;
		}
		return super.get_edge_weight(source, sink);
	}

	/**
	 * Return the weight associated with the input edge.
	 * 
	 * @param source
	 * @param sink
	 * @return
	 */
	public double get_edge_weight_of_graph(BaseVertex source, BaseVertex sink)
	{
		return super.get_edge_weight(source, sink);
	}
	
	/**
	 * Return the set of fan-outs of the input vertex.
	 * 
	 * @param vertex
	 * @return
	 */
	public Set<BaseVertex> get_adjacent_vertices(BaseVertex vertex)
	{
		Set<BaseVertex> ret_set = new HashSet<BaseVertex>();
		int starting_vertex_id = vertex.get_id();
		if(!_rem_vertex_id_set.contains(starting_vertex_id))
		{
			Set<BaseVertex> adj_vertex_set = super.get_adjacent_vertices(vertex);
			for(BaseVertex cur_vertex : adj_vertex_set)
			{
				int ending_vertex_id = cur_vertex.get_id();
				if(_rem_vertex_id_set.contains(ending_vertex_id)
				|| _rem_edge_set.contains(
						new Pair<Integer,Integer>(starting_vertex_id, ending_vertex_id)))
				{
					continue;
				}
				
				// 
				ret_set.add(cur_vertex);
			}
		}
		return ret_set;
	}

	/**
	 * Get the set of vertices preceding the input vertex.
	 * 
	 * @param vertex
	 * @return
	 */
	public Set<BaseVertex> get_precedent_vertices(BaseVertex vertex)
	{
		Set<BaseVertex> ret_set = new HashSet<BaseVertex>();
		if(!_rem_vertex_id_set.contains(vertex.get_id()))
		{
			int ending_vertex_id = vertex.get_id();
			Set<BaseVertex> pre_vertex_set = super.get_precedent_vertices(vertex);
			for(BaseVertex cur_vertex : pre_vertex_set)
			{
				int starting_vertex_id = cur_vertex.get_id();
				if(_rem_vertex_id_set.contains(starting_vertex_id) 
				|| _rem_edge_set.contains(
						new Pair<Integer, Integer>(starting_vertex_id, ending_vertex_id))) 
				{
					continue;
				}
				
				//
				ret_set.add(cur_vertex);
			}
		}
		return ret_set;
	}

	/**
	 * Get the list of vertices in the graph, except those removed.
	 * @return
	 */
	public List<BaseVertex> get_vertex_list()
	{
		List<BaseVertex> ret_list = new Vector<BaseVertex>();
		for(BaseVertex cur_vertex : super.get_vertex_list())
		{
			if(_rem_vertex_id_set.contains(cur_vertex.get_id())) continue;
			ret_list.add(cur_vertex);
		}
		return ret_list;
	}

	/**
	 * Get the vertex corresponding to the input 'id', if exist. 
	 * 
	 * @param id
	 * @return
	 */
	public BaseVertex get_vertex(int id)
	{
		if(_rem_vertex_id_set.contains(id))
		{
			return null;
		}else
		{
			return super.get_vertex(id);
		}
	}

	/**
	 * @param args
	 */
	public static void main(String[] args)
	{
		System.out.println("Welcome to the class VariableGraph!");
		
		VariableGraph graph = new VariableGraph("data/test_50");
		graph.remove_vertex(13);
		graph.remove_vertex(12);
		graph.remove_vertex(10);
		graph.remove_vertex(23);
		graph.remove_vertex(47);
		graph.remove_vertex(49);
		graph.remove_vertex(3);
		graph.remove_edge(new Pair<Integer, Integer>(26, 41));
		DijkstraShortestPathAlg alg = new DijkstraShortestPathAlg(graph);
		System.out.println(alg.get_shortest_path(graph.get_vertex(0), graph.get_vertex(20)));
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
3d成人动漫网站| 精品国产乱码久久久久久闺蜜| 日韩—二三区免费观看av| 综合色中文字幕| 337p粉嫩大胆色噜噜噜噜亚洲| 欧美曰成人黄网| 成年人午夜久久久| 国产高清亚洲一区| 日本不卡一区二区三区| 亚洲一区二区三区四区在线观看 | 欧美群妇大交群的观看方式| bt7086福利一区国产| 国产激情视频一区二区在线观看| 日韩精品一二区| 五月天激情综合| 日韩高清在线观看| 日本欧美一区二区| 捆绑变态av一区二区三区| 看片的网站亚洲| 国精品**一区二区三区在线蜜桃| 免费观看30秒视频久久| 精品一区二区三区在线观看| 久久国产精品99精品国产 | 国产精品正在播放| 欧美日韩一二三区| a级高清视频欧美日韩| 色婷婷亚洲一区二区三区| 日本精品裸体写真集在线观看| 欧美天堂一区二区三区| 欧美伦理视频网站| 久久免费偷拍视频| 亚洲欧洲色图综合| 日韩综合一区二区| 国产成人精品影视| 在线视频亚洲一区| 亚洲精品在线观| 一二三四社区欧美黄| 免费观看在线综合| 色久综合一二码| 久久一区二区视频| 亚洲成人你懂的| 国产精品一二三四五| 欧美亚洲国产怡红院影院| 久久嫩草精品久久久久| 一区二区三区日韩欧美| 国产精品一区二区三区网站| 一本久久a久久免费精品不卡| 日韩免费在线观看| 国产精品一区二区久久不卡 | 成人免费的视频| 欧美久久一二三四区| 国产精品久线在线观看| 国精品**一区二区三区在线蜜桃| 欧美在线观看一二区| 综合久久久久综合| 成人一道本在线| 26uuu精品一区二区三区四区在线| 中文字幕一区二区三区精华液| 麻豆精品视频在线观看视频| 91美女蜜桃在线| 欧美国产成人精品| 国产成人av电影在线观看| 日韩一区二区高清| 六月丁香综合在线视频| 日韩欧美激情四射| 久久99精品网久久| 欧美精品一区二区三| 久久97超碰色| 国产亚洲精品超碰| 成人av电影免费在线播放| 中文字幕成人av| 97se亚洲国产综合自在线观| 中文字幕一区二区三中文字幕| 国产精品亚洲一区二区三区在线| 久久女同互慰一区二区三区| 国产精品一区二区91| 中文字幕欧美区| 91在线视频官网| 国产一区二区在线视频| 中文字幕精品三区| 91丝袜国产在线播放| 一区二区三区在线视频播放| 欧美日韩一区成人| 久久草av在线| 一区二区三区四区乱视频| 制服丝袜亚洲播放| 成人美女视频在线观看| 一区二区在线观看免费视频播放| 欧美中文一区二区三区| 国产一区二区精品久久| 亚洲高清视频在线| 国产日本欧洲亚洲| 欧美日韩国产综合视频在线观看| 麻豆精品在线看| 亚洲一区二区三区四区在线免费观看 | 国产一区在线不卡| 亚洲国产精品一区二区久久恐怖片| 欧美大片日本大片免费观看| 99精品久久只有精品| 美女被吸乳得到大胸91| 亚洲乱码国产乱码精品精可以看| 日韩欧美国产三级| 在线视频你懂得一区二区三区| 另类小说欧美激情| 亚洲 欧美综合在线网络| 亚洲日本va午夜在线电影| 久久天堂av综合合色蜜桃网| 欧美精品免费视频| 欧美日韩国产天堂| 日本精品视频一区二区| 色婷婷激情综合| 色婷婷综合视频在线观看| 国产v综合v亚洲欧| 欧美日韩成人综合天天影院| www.欧美.com| 99国产欧美另类久久久精品| 国产69精品久久99不卡| 国产美女久久久久| 国产夫妻精品视频| 成人黄色免费短视频| 99这里都是精品| 日本精品视频一区二区三区| 欧美日韩一区二区三区四区 | 欧美视频完全免费看| 欧美日韩中文字幕精品| 欧美午夜理伦三级在线观看| 欧洲精品一区二区三区在线观看| 成人免费的视频| 欧美日韩一区二区三区不卡 | 欧美精品日韩综合在线| 日韩欧美精品三级| 欧美韩国一区二区| 亚洲一级二级三级在线免费观看| 天堂影院一区二区| 国产精品综合一区二区| 波多野结衣精品在线| 欧美日韩情趣电影| 亚洲精品一区二区精华| 成人欧美一区二区三区在线播放| 亚洲精品国产无天堂网2021| 青青草成人在线观看| 国产成人在线看| 在线观看日韩毛片| 久久久久久久久一| 亚洲一区在线电影| 成人三级在线视频| 欧美一区二区三区播放老司机| 欧美激情中文字幕| 麻豆成人久久精品二区三区红| 国产成人综合网| 56国语精品自产拍在线观看| 国产精品亲子伦对白| 久久精品国产成人一区二区三区| 成人av网站在线观看| 精品国产91洋老外米糕| 一区二区激情视频| www.亚洲在线| 国产日产欧美一区二区三区| 天堂蜜桃91精品| 欧美日韩卡一卡二| 久久99久久精品欧美| 欧美亚洲国产一卡| 亚洲第一二三四区| 在线一区二区三区四区五区| 国产精品美女www爽爽爽| 国产成人亚洲精品青草天美| 精品国产乱码久久久久久免费 | 欧美一区二区视频网站| 午夜精品一区二区三区电影天堂| 99re6这里只有精品视频在线观看| 国产精品入口麻豆九色| 成人激情免费电影网址| 国产精品女同互慰在线看| 国产99久久久国产精品| 中文字幕在线观看一区二区| 成人18视频日本| 亚洲黄色免费网站| 欧美色成人综合| 日韩精品免费专区| 精品久久国产老人久久综合| 国产一区二区三区黄视频| 中文av一区二区| 欧美无砖专区一中文字| 久久精品99久久久| 国产精品日日摸夜夜摸av| 91片黄在线观看| 久久精品久久99精品久久| 国产清纯美女被跳蛋高潮一区二区久久w| 国产美女精品在线| 一区二区三区高清| 精品国产123| 欧美专区在线观看一区| 看电视剧不卡顿的网站| 欧美韩日一区二区三区四区| 欧美视频一区二区| 国产精品系列在线观看| 香蕉久久一区二区不卡无毒影院 | 欧洲另类一二三四区| 国产又黄又大久久| 亚洲一区二区影院|