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

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

?? form1.cs

?? 最短路徑算法,可以實現從一個站點到另一個站點的最短路徑搜尋
?? CS
字號:
using System;
using System.Drawing;
using System.Collections;
using System.ComponentModel;
using System.Windows.Forms;
using System.Data;
using System.Data.OleDb;

namespace shtpath
{
	/// <summary>
	/// Form1 的摘要說明。
	/// </summary>
	public class Form1 : System.Windows.Forms.Form
	{
		private System.Windows.Forms.ComboBox comboBox1;
		private System.Windows.Forms.ComboBox comboBox2;
		private System.Windows.Forms.Label label1;
		private System.Windows.Forms.Label label2;
		private System.Windows.Forms.RichTextBox richTextBox1;
		public int startID;
		public int endID;
		private System.Windows.Forms.Button button1;
		public int [,]map=new int[,]{{0,3,4,0,0,0},
									 {3,0,0,2,5,0},
									 {0,0,0,0,1,0},
									 {0,0,0,0,0,4},
									 {0,0,1,0,0,6},
									 {0,0,0,4,0,0}};
		public ArrayList open;
		public ArrayList closed;
			/// <summary>
			/// 必需的設計器變量。
			/// </summary>
			private System.ComponentModel.Container components = null;

		public Form1()
		{
			//
			// Windows 窗體設計器支持所必需的
			//
			InitializeComponent();

			//
			// TODO: 在 InitializeComponent 調用后添加任何構造函數代碼
			//
		}

		/// <summary>
		/// 清理所有正在使用的資源。
		/// </summary>
		protected override void Dispose( bool disposing )
		{
			if( disposing )
			{
				if (components != null)
				{
					components.Dispose();
				}
			}
			base.Dispose( disposing );
		}

		#region Windows 窗體設計器生成的代碼
		/// <summary>
		/// 設計器支持所需的方法 - 不要使用代碼編輯器修改
		/// 此方法的內容。
		/// </summary>
		private void InitializeComponent()
		{
			this.comboBox1 = new System.Windows.Forms.ComboBox();
			this.comboBox2 = new System.Windows.Forms.ComboBox();
			this.label1 = new System.Windows.Forms.Label();
			this.label2 = new System.Windows.Forms.Label();
			this.richTextBox1 = new System.Windows.Forms.RichTextBox();
			this.button1 = new System.Windows.Forms.Button();
			this.SuspendLayout();
			// 
			// comboBox1
			// 
			this.comboBox1.Items.AddRange(new object[] {
														   "1",
														   "2",
														   "3",
														   "4",
														   "5",
														   "6"});
			this.comboBox1.Location = new System.Drawing.Point(56, 8);
			this.comboBox1.Name = "comboBox1";
			this.comboBox1.Size = new System.Drawing.Size(88, 20);
			this.comboBox1.TabIndex = 1;
			this.comboBox1.SelectedIndexChanged += new System.EventHandler(this.comboBox1_SelectedIndexChanged);
			// 
			// comboBox2
			// 
			this.comboBox2.Items.AddRange(new object[] {
														   "1",
														   "2",
														   "3",
														   "4",
														   "5",
														   "6"});
			this.comboBox2.Location = new System.Drawing.Point(208, 8);
			this.comboBox2.Name = "comboBox2";
			this.comboBox2.Size = new System.Drawing.Size(88, 20);
			this.comboBox2.TabIndex = 2;
			this.comboBox2.SelectedIndexChanged += new System.EventHandler(this.comboBox2_SelectedIndexChanged);
			// 
			// label1
			// 
			this.label1.Location = new System.Drawing.Point(16, 8);
			this.label1.Name = "label1";
			this.label1.Size = new System.Drawing.Size(32, 16);
			this.label1.TabIndex = 3;
			this.label1.Text = "起點";
			// 
			// label2
			// 
			this.label2.Location = new System.Drawing.Point(168, 8);
			this.label2.Name = "label2";
			this.label2.Size = new System.Drawing.Size(32, 16);
			this.label2.TabIndex = 4;
			this.label2.Text = "終點";
			// 
			// richTextBox1
			// 
			this.richTextBox1.Location = new System.Drawing.Point(0, 40);
			this.richTextBox1.Name = "richTextBox1";
			this.richTextBox1.Size = new System.Drawing.Size(384, 264);
			this.richTextBox1.TabIndex = 5;
			this.richTextBox1.Text = "";
			// 
			// button1
			// 
			this.button1.Location = new System.Drawing.Point(320, 8);
			this.button1.Name = "button1";
			this.button1.Size = new System.Drawing.Size(56, 23);
			this.button1.TabIndex = 6;
			this.button1.Text = "查詢";
			this.button1.Click += new System.EventHandler(this.button1_Click);
			// 
			// Form1
			// 
			this.AutoScaleBaseSize = new System.Drawing.Size(6, 14);
			this.ClientSize = new System.Drawing.Size(384, 301);
			this.Controls.Add(this.button1);
			this.Controls.Add(this.richTextBox1);
			this.Controls.Add(this.label2);
			this.Controls.Add(this.label1);
			this.Controls.Add(this.comboBox2);
			this.Controls.Add(this.comboBox1);
			this.Name = "Form1";
			this.Text = "最短路徑演示";
			this.Load += new System.EventHandler(this.Form1_Load);
			this.ResumeLayout(false);

		}
		#endregion

		/// <summary>
		/// 應用程序的主入口點。
		/// </summary>
		[STAThread]
		static void Main() 
		{
			Application.Run(new Form1());
		}

		private void Form1_Load(object sender, System.EventArgs e)
		{
			richTextBox1.Clear();
			closed=new ArrayList(50);
			open=new ArrayList(50);
			closed.Clear();
			open.Clear();
		}
		private void FindPath(int startno,int endno)
		{
			int j,k,k1,k2;
			int min=100;
			int row,colum;
			node current=new node();//closed中最后進入的點為當前結點
			node near=new node();//在open中距離起點最近的結點
			node next=new node();//待擴展的結點
			//起點初始化操作
			node n=new node();
			n.nodeID=startno;
			n.dTotalLong=0;
			n.lastNodeID=0;
			closed.Add(n);
			int num=closed.Count;
			while(((node)closed[num-1]).nodeID!=endno)
			{
				current.nodeID=((node)closed[num-1]).nodeID;
				current.dTotalLong=((node)closed[num-1]).dTotalLong;
				current.lastNodeID=((node)closed[num-1]).lastNodeID;
				row=current.nodeID-1;
				//擴展當前結點的后繼結點
				for(colum=0;colum<6;colum++)
				{
					if(map[row,colum]!=0)
					{
						next.nodeID=colum+1;
						next.lastNodeID=current.nodeID;
						next.dTotalLong=current.dTotalLong+map[row,colum];
						for(k1=0;k1<closed.Count;k1++)
						{
							if(next.nodeID==((node)closed[k1]).nodeID)//表明在closed隊列中
								break;
						}
							if(k1==closed.Count)//表明不在closed隊列中
							{
								//判斷該后繼結點是否在open隊列中
								for(k2=0;k2<open.Count;k2++)
								{
									if(next.nodeID==((node)open[k2]).nodeID)//在open中
									{
										if(next.dTotalLong<((node)open[k2]).dTotalLong)
										{	
											((node)open[k2]).dTotalLong=next.dTotalLong;
											((node)open[k2]).lastNodeID=next.lastNodeID;
											break;
										}
									}
								}
								if(k2==open.Count)
								{
									open.Add(next);
								}
							}
					}
				}
				//在open隊列中尋找離起點最近的點
				for(j=0;j<open.Count;j++)
				{
					if(min>((node)open[j]).dTotalLong)
					{
						min=((node)open[j]).dTotalLong;
						near.nodeID=((node)open[j]).nodeID;
						near.lastNodeID=((node)open[j]).lastNodeID;
						near.dTotalLong=((node)open[j]).dTotalLong;
						//k=j;
					}
				}
				closed.Add(near);
				num=closed.Count;
				for(j=0;j<open.Count;j++)
					if(near.nodeID==((node)open[j]).nodeID)
						break;
				//((node)open[j]).dTotalLong=20;
				open.RemoveAt(j);
			}
			
		}

		private void button1_Click(object sender, System.EventArgs e)
		{
			richTextBox1.Clear();
			this.FindPath(startID,endID);
			int startno;
			int i;
			startno=endID;
			while(startno!=startID)
			{
				for(i=0;i<closed.Count;i++)
				{
					if(startno==((node)closed[i]).nodeID)
					{
						richTextBox1.Text="-->"+startno.ToString()+richTextBox1.Text;
						startno=((node)closed[i]).lastNodeID;
					}
				}
			}
			richTextBox1.Text=startID.ToString()+richTextBox1.Text;
		}

		private void comboBox1_SelectedIndexChanged(object sender, System.EventArgs e)
		{
			startID=int.Parse(comboBox1.Text);
		}

		private void comboBox2_SelectedIndexChanged(object sender, System.EventArgs e)
		{
			endID=int.Parse(comboBox2.Text);
		}
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成a人片国产精品| 成人精品在线视频观看| 一区二区三区欧美亚洲| 亚洲四区在线观看| 国产精品久久久99| 日韩美女啊v在线免费观看| 亚洲欧洲制服丝袜| 亚洲影视资源网| 日韩国产在线观看| 精品午夜久久福利影院 | 欧美中文字幕一区| 色又黄又爽网站www久久| 一本大道久久a久久精二百| 欧美亚洲动漫精品| 7777精品伊人久久久大香线蕉| 91精品国产综合久久久久久| 日韩区在线观看| 国产视频一区二区三区在线观看| 国产精品久久久久毛片软件| 亚洲欧美成人一区二区三区| 婷婷夜色潮精品综合在线| 美女一区二区视频| youjizz久久| 欧美中文字幕一区二区三区亚洲| 日韩欧美一级二级| 欧美精品一区二区三区高清aⅴ | 91在线视频观看| 欧美肥胖老妇做爰| 久久九九99视频| 亚洲午夜在线电影| thepron国产精品| 在线免费观看日本一区| 精品日本一线二线三线不卡 | 不卡的电影网站| 欧美图片一区二区三区| 久久精品视频网| 亚洲精品视频观看| 国产一区中文字幕| 欧美日韩一区二区电影| 久久九九久久九九| 日日夜夜免费精品| av一区二区三区黑人| 7777精品久久久大香线蕉| 中文字幕日韩精品一区 | 国产乱码精品一区二区三区忘忧草| 色综合天天狠狠| 久久综合狠狠综合久久综合88| 亚洲一区二区欧美| 99麻豆久久久国产精品免费| 日韩欧美高清在线| 五月天激情综合| 91网站最新地址| 国产三级一区二区| 麻豆成人在线观看| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 精品国产麻豆免费人成网站| 亚洲精品国产视频| youjizz国产精品| 国产亚洲综合av| 麻豆freexxxx性91精品| 欧美日韩视频在线观看一区二区三区| 中文一区二区在线观看| 国产剧情一区在线| 精品捆绑美女sm三区| 免费日韩伦理电影| 制服丝袜在线91| 亚洲国产成人av好男人在线观看| 91视视频在线直接观看在线看网页在线看 | 不卡av在线网| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 国产激情视频一区二区三区欧美| 欧美一级午夜免费电影| 三级亚洲高清视频| 91精品麻豆日日躁夜夜躁| 天天免费综合色| 欧美一区二区三区男人的天堂| 天天操天天综合网| 日韩午夜av一区| 激情综合网激情| xnxx国产精品| 成人在线视频首页| 亚洲天堂成人网| 欧美偷拍一区二区| 秋霞电影网一区二区| 精品成人a区在线观看| 国产麻豆日韩欧美久久| 国产精品拍天天在线| 色综合天天做天天爱| 亚洲另类春色国产| 在线播放欧美女士性生活| 麻豆精品新av中文字幕| 欧美精品一区视频| av资源网一区| 亚洲在线视频免费观看| 91精品免费在线观看| 国产精品综合av一区二区国产馆| 国产精品美女久久久久av爽李琼| 色综合视频在线观看| 日韩av电影天堂| 久久日一线二线三线suv| 成人精品电影在线观看| 亚洲丰满少妇videoshd| 精品久久一区二区三区| kk眼镜猥琐国模调教系列一区二区| 亚洲精品高清视频在线观看| 4438亚洲最大| 成人激情小说网站| 日本午夜一本久久久综合| 国产亚洲综合色| 色94色欧美sute亚洲线路一ni| 国产高清精品在线| 一区二区不卡在线播放| 日韩视频国产视频| 色婷婷精品久久二区二区蜜臂av | 欧美写真视频网站| 国产精品正在播放| 亚洲sss视频在线视频| 欧美极品少妇xxxxⅹ高跟鞋| 欧美日韩高清在线| 99国产欧美另类久久久精品| 久久精品国产第一区二区三区| 中文字幕中文字幕一区二区| 欧美大黄免费观看| 欧洲一区二区av| 国产成人日日夜夜| 免费成人在线观看视频| 一区二区三区蜜桃网| 欧美激情在线一区二区| 91精品国产入口| 在线观看网站黄不卡| 北条麻妃一区二区三区| 国产综合久久久久久鬼色| 亚洲第一激情av| 一区二区欧美在线观看| 亚洲欧美综合网| 国产欧美日韩亚州综合| 久久亚洲精品国产精品紫薇 | 国产一二精品视频| 日本不卡123| 日日夜夜精品视频免费| 亚洲狠狠爱一区二区三区| 1000精品久久久久久久久| 中文字幕av一区二区三区免费看| 日韩欧美视频一区| 欧美一区二区免费观在线| 欧美日韩亚洲另类| 欧洲精品视频在线观看| 91久久国产综合久久| 一本久久精品一区二区| 99久久精品免费看国产 | 日韩电影在线免费| 日韩精品91亚洲二区在线观看| 午夜av区久久| 天天色天天操综合| 日本v片在线高清不卡在线观看| 日本亚洲视频在线| 蜜桃免费网站一区二区三区| 久久99深爱久久99精品| 久久av资源站| 国产乱国产乱300精品| 国产高清精品在线| 99久久综合99久久综合网站| 色综合天天综合| 欧美主播一区二区三区| 91精品国产乱| 精品国产一二三| 国产精品美女一区二区| 一区二区高清在线| 日本不卡一二三区黄网| 精品无码三级在线观看视频| 风间由美性色一区二区三区| 91麻豆蜜桃一区二区三区| 欧美精选午夜久久久乱码6080| 制服丝袜中文字幕一区| 久久久青草青青国产亚洲免观| 国产精品视频在线看| 亚洲综合在线第一页| 麻豆国产精品一区二区三区| 成人午夜激情影院| 欧洲中文字幕精品| 日韩精品一区国产麻豆| 中文字幕一区二区三区在线播放| 亚洲成av人影院| 国产精品一区二区男女羞羞无遮挡 | aaa国产一区| 精品视频在线免费观看| 久久久久久麻豆| 亚洲一区二区三区四区在线 | 亚洲欧美怡红院| 麻豆视频观看网址久久| 92国产精品观看| 精品日韩成人av| 亚洲一区免费观看| 国产v日产∨综合v精品视频| 欧美色电影在线| 国产日韩欧美综合一区| 午夜成人在线视频| 色综合咪咪久久| 久久久久国产精品免费免费搜索 | 2024国产精品视频|