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

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

?? algbb.cpp

?? *程序AlgBB用于求解甲乙城市之間的最短路徑的分支限界問題 * //*輸入:距離文件m1.txt
?? CPP
字號:
//*************************************************************
//*程序AlgBB用于求解甲乙城市之間的最短路徑的分支限界問題	  *
//*輸入:距離文件m1.txt,耗費文件m2.txt						  *
//*輸出:甲乙城市間的具體最短路徑及其總長度和總耗費		      *
//*************************************************************

#include <iostream>
#include <fstream>
using namespace std;

const int MAX=9999;

//類HeapNode:用于構造類的節點
class HeapNode
{
	public:
		HeapNode()
		{
			n=0;
		}
		HeapNode(const HeapNode& );
		HeapNode& operator=(const HeapNode&);
		int length;		//當前路徑長度的邊界
		int cost;		//所耗養路費的值
		int num;		//城市的編號
		int path[50];	//到該節點所經過的路徑
		int n;			//路徑中的頂點數(城市數)
};

//構造函數
HeapNode::HeapNode(const HeapNode& a)
{
	int i;
	length=a.length;
	cost=a.cost;
	num=a.num;
	n=a.n;
	for(i=0;i<a.n;i++)
	{
		path[i]=a.path[i];
	}
}

//賦值操作符重載
HeapNode& HeapNode::operator =(const HeapNode& a)
{
	int i;
	length=a.length;
	cost=a.cost;
	num=a.num;
	n=a.n;
	for(i=0;i<a.n;i++)
	{
		path[i]=a.path[i];
	}
	return *this;
}

//類Heap:用于最小堆的構造
class Heap
{
	public:
		Heap(int heapSize);				//構造函數
		void delNode(HeapNode & x);		//從堆中刪除最小元素
		void insNode(HeapNode & x);		//向堆中插入元素
		bool isEmpty();					//判斷堆是否為空
	private:
		int size;						//堆的最大容量
		int n;							//當前堆的大小
		HeapNode * heap;				//指向堆的指針
		void moveUp(int i);				//用于在堆中從下到上交換元素
		void moveDown(int i);			//用于在堆中從上到下交換元素
};

//構造函數
Heap::Heap(int heapSize)
{
	heap=new HeapNode[heapSize];
	size=heapSize;
	n=0;
}

//判斷堆是否為空
bool Heap::isEmpty()
{
	if(n<=0)
	{
		return true;
	}
	else
	{
		return false;
	}
}

//用于在堆中從下到上交換元素
void Heap::moveUp(int i)
{
	while(i>0)
	{
		if(heap[i].length < heap[(i-1)/2].length)
		{
			HeapNode a=heap[i];
			heap[i]=heap[(i-1)/2];
			heap[(i-1)/2]=a;
			i=(i-1)/2;
		}
		else 
		{
			return;
		}
	}
	return;
}

//用于在堆中從上到下交換元素
void Heap::moveDown(int i)
{
	while((2*i+1) < n)
	{
		i=2*i+1;
		if(i+1<n)
		{
			if(heap[i].length > heap[i+1].length)
			{
				i=i+1;
			}
		}
		if(heap[(i-1)/2].length > heap[i].length)
		{
			HeapNode a=heap[i];
			heap[i]=heap[(i-1)/2];
			heap[(i-1)/2]=a;
		}
		else
		{
			return;
		}
	}
	return;
}

//從堆中刪除最小元素
void Heap::delNode(HeapNode& x)
{
	x=heap[0];
	heap[0]=heap[n-1];
	if(--n<=0)
	{
		return;
	}
	moveDown(0);
}

//向堆中插入元素
void Heap::insNode(HeapNode& x)
{
	heap[n++]=x;
	moveUp(n-1);
	
}

//利用分枝定界法求解最短路徑
void AlgBB(int cost[51][51],int length[51][51])
{
	int i,j,tmp,u,n,min,shortestCost,s[51];
	int distance[51];			//用于存放到目的地最短路徑長度
	int path[50];				//到目前為止的最短路徑
	int pathLength=0;			//目前路徑中包含的結點數

	Heap heap(200);				//構造堆
	HeapNode node;
	n=50;
	min=MAX;
	node.num=1;
	node.cost=0;
	node.path[node.n++]=1;

	for(i=1;i<n;i++)
	{
		distance[i]=length[i][50];
		s[i]=false;
	}
	for(i=1;i<n;i++)
	{
		tmp=MAX;
		for(j=1;j<n;j++)
		{
			if(!s[j] && (distance[j]<tmp))
			{
				tmp=distance[j];
				u=j;
			}
		}
		if(tmp<MAX)
		{
			s[u]=true;
			for(j=1;j<n;j++)
			{
				if(!s[j] && (distance[u]+length[j][u]<distance[j]))
				{
					distance[j]=distance[u]+length[j][u];
				}
			}
		}
	}

	node.length=distance[1];

	//遍歷解空間樹
	for(;;)
	{
		for(i=1;i<=n;i++)
		{
			//判斷是否剪枝
			if((length[node.num][i] < MAX) && (node.cost+cost[node.num][i]<=1500) && (node.length-distance[node.num]+length[node.num][i]+distance[i]<=min))
			{
				//是否到達目的地
				if(i==50)
				{
					if(node.length+length[node.num][i]-distance[node.num]<=min)
					{
						for(j=0;j<node.n;j++)
						{
							path[j]=node.path[j];
						}
						path[node.n]=50;
						pathLength=node.n+1;
						min=node.length+length[node.num][i]-distance[node.num];
					}				
					continue;
				}

				//查看是否出現回路
				for(j=0;j<node.n;j++)
				{
					if(node.path[j]==i)
					{
						break;
				
					}
				}
				//將節點其插入最小堆中
				if(node.n==j)
				{
					HeapNode tmp;
					tmp.num=i;
					tmp.length=node.length-distance[node.num]+length[node.num][i]+distance[i];
					tmp.cost=node.cost+cost[node.num][i];
					tmp.n=node.n+1;
					for(j=0;j<node.n;j++)
					{
						tmp.path[j]=node.path[j];
					}
					tmp.path[node.n]=i;
					heap.insNode(tmp);
				}
			}
		}

		//每次從優先隊列中取一個最小的結點
		while(true)
		{
			//如果隊列為空則輸出結果
			if(heap.isEmpty())
			{
				cout<<"算法AlgBB所得結果:"<<endl;
				cout<<"甲乙之間最短路線長度是:"<<min<<endl;
				shortestCost=0;
				for(i=0;i<pathLength-1;i++)
				{
					shortestCost+=cost[path[i]][path[i+1]];
				}
				cout<<"最短路線收取的費用是:"<<shortestCost<<endl;
				cout<<"最短路徑是:"<<endl;
				for(i=0;i<pathLength;i++)
				{
					cout<<path[i]<<"	";
				}
				cout<<endl;
				return;
			}
			//隊列不為空則取出堆中的最小結點
			heap.delNode(node);
			//判斷是否剪枝
			if(node.length>min)
			{
				continue;
			}
			else
			{
				break;
			}
		}
	}
}

int main()
{
	int i,j,n;
	int cost[51][51];						//耗費矩陣
	int length[51][51];						//距離矩陣

	ifstream inFile;			
	//讀文件m1.txt到length矩陣中
	inFile.open("m1.txt");					
	n=50;
	for(i=1;i<=n;i++)
	{
		for(j=1;j<=n;j++)
		{
			inFile>>length[i][j];
		}
	}
	inFile.close();
	//讀文件m2.txt到cost矩陣中
	inFile.open("m2.txt");
	for(i=1;i<=n;i++)
	{
		for(j=1;j<=n;j++)
		{
			inFile>>cost[i][j];
		}
	}
	inFile.close();
	//調用分支限界函數求解
	AlgBB(cost,length);
	return 1;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一本到不卡免费一区二区| 国产成人精品影院| 色妹子一区二区| 亚洲在线一区二区三区| 国产精品视频一区二区三区不卡| 欧美夫妻性生活| 欧美色网站导航| 91视频国产资源| 国产成人精品1024| 狠狠狠色丁香婷婷综合久久五月| 国产**成人网毛片九色 | 日韩av中文字幕一区二区三区| 综合精品久久久| 亚洲高清免费视频| 亚洲国产视频一区二区| 国产一区在线视频| 色先锋资源久久综合| 99久久精品国产精品久久| 国内久久精品视频| 狠狠色狠狠色合久久伊人| 秋霞午夜av一区二区三区| 成人国产免费视频| 国产成人三级在线观看| 国产欧美一区二区精品性色超碰 | 国产一区美女在线| 美美哒免费高清在线观看视频一区二区 | 欧美日韩精品是欧美日韩精品| 色婷婷一区二区三区四区| 成人的网站免费观看| 91香蕉视频在线| 欧美日韩在线三区| 欧美一区二区三区精品| 7777精品伊人久久久大香线蕉的| 91精品在线观看入口| 欧美大胆一级视频| 久久久久久久久久久99999| 日韩一级视频免费观看在线| 欧美电视剧在线看免费| 国产亚洲精品aa午夜观看| 国产精品免费人成网站| 国产婷婷色一区二区三区| 国产日韩av一区| 亚洲欧美国产毛片在线| 亚洲成人av免费| 国产麻豆视频一区| 风间由美一区二区三区在线观看| 成人福利视频在线| 欧美日韩国产免费| 久久久久久久国产精品影院| 国产精品不卡在线观看| 日韩精品视频网| 粉嫩av一区二区三区粉嫩| 欧美色精品在线视频| 精品日韩99亚洲| 国产精品视频在线看| 一区二区三区在线观看动漫| 免费高清视频精品| 色婷婷亚洲综合| 久久色.com| 日韩一区在线看| 国产精品亚洲午夜一区二区三区| 91高清视频免费看| 国产精品污网站| 午夜久久久久久| 色综合天天做天天爱| 欧美成人性战久久| 亚洲小说春色综合另类电影| 国产精品一二三在| 欧美一区二区久久| 一区二区三区国产| 成人免费毛片aaaaa**| 日韩三级在线免费观看| 亚洲一区二区三区精品在线| 免费在线观看不卡| 欧美午夜精品免费| 亚洲色图丝袜美腿| 成人av影院在线| 久久综合色播五月| 天天综合网天天综合色| 99麻豆久久久国产精品免费优播| 日韩精品一区二区在线观看| 亚洲成av人片在线观看无码| 国产suv精品一区二区三区| 日韩你懂的在线观看| 日本亚洲欧美天堂免费| 欧美色涩在线第一页| 夜夜嗨av一区二区三区四季av| 高清不卡一区二区| 欧美国产一区视频在线观看| 国产一区二区三区久久悠悠色av | 午夜一区二区三区视频| 在线免费观看日本欧美| 亚洲欧洲在线观看av| 成人avav影音| 亚洲免费在线视频| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 99精品欧美一区二区三区小说 | 久久99国产精品麻豆| 久久免费午夜影院| 色婷婷综合久久久| 奇米精品一区二区三区在线观看| xnxx国产精品| 色中色一区二区| 免费观看日韩av| 国产精品卡一卡二卡三| 欧美福利视频导航| 欧美日韩五月天| 精品一区二区精品| 最新中文字幕一区二区三区| 777a∨成人精品桃花网| 成人午夜激情视频| 免费高清在线视频一区·| 国产精品国产三级国产专播品爱网 | 亚洲成a天堂v人片| 国产亚洲一本大道中文在线| 91精品福利视频| 国产在线精品一区在线观看麻豆| 亚洲欧美国产毛片在线| 精品国产一区二区三区久久久蜜月| 99精品视频一区| 国产在线精品一区二区 | 欧美一二三在线| 97久久超碰国产精品| 国产精品自产自拍| 日韩综合在线视频| 亚洲精品国产成人久久av盗摄| 久久综合九色综合97婷婷| 欧美在线一区二区| 成人精品免费网站| 国产精品一区二区在线观看网站 | 中文乱码免费一区二区| 91精品一区二区三区在线观看| av男人天堂一区| 国产激情91久久精品导航| 美女精品一区二区| 日本伊人色综合网| 偷窥国产亚洲免费视频| 亚洲视频在线观看三级| 国产精品午夜免费| 久久精品一区二区三区av| 日韩欧美自拍偷拍| 88在线观看91蜜桃国自产| 在线观看日韩精品| 91国偷自产一区二区使用方法| 北岛玲一区二区三区四区| 欧美中文字幕一区| 日本福利一区二区| 色综合色狠狠天天综合色| 91亚洲永久精品| 91在线精品一区二区三区| a4yy欧美一区二区三区| 成人动漫在线一区| 99久久伊人久久99| proumb性欧美在线观看| 99久久国产综合精品女不卡| 成人久久久精品乱码一区二区三区| 国产精品99久久久久久久女警| 精品一区二区成人精品| 国产精品一线二线三线| 国产一区 二区| 成人深夜视频在线观看| 97se亚洲国产综合在线| 色婷婷综合久久久久中文一区二区 | 国产精品乱码久久久久久| 精品国偷自产国产一区| 久久久美女毛片| 国产精品国产三级国产a | 欧美色爱综合网| 欧美精品日韩精品| 亚洲精品视频在线看| 一个色妞综合视频在线观看| 亚洲综合一区二区三区| 天天av天天翘天天综合网色鬼国产 | 免费欧美高清视频| 久久国产福利国产秒拍| 国产精品1区二区.| 成人av在线一区二区| 欧美亚洲动漫另类| 久久一日本道色综合| 亚洲人妖av一区二区| 日本 国产 欧美色综合| 成人理论电影网| 制服丝袜中文字幕一区| 国产丝袜欧美中文另类| 亚洲猫色日本管| 毛片av一区二区| av电影在线观看不卡| 777a∨成人精品桃花网| 国产精品美女久久久久久| 天天影视网天天综合色在线播放| 国产99久久久国产精品免费看| 欧美亚洲国产一区二区三区| 国产日韩欧美不卡在线| 午夜精品久久久久久久| 粉嫩av一区二区三区粉嫩 | 国产精品69毛片高清亚洲| 在线视频欧美区| 国产精品视频一二三区| 免费视频一区二区| 欧洲视频一区二区|