国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

1018. Public Bike Management 解析

2019-11-14 12:04:35
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

單用Dijstra算法比較難維護(hù)。用Dijstra+DFS能簡(jiǎn)化不少。

看到有小伙伴例7有問(wèn)題,可以看下是不是Dijstra的算法在計(jì)算路徑的時(shí)候出問(wèn)題沒(méi)。我的就是下標(biāo)u和i弄混了。查了好久。。。。。

#include <iostream>#include <vector>#include <string>#include <climits>#include <stack>using namespace std;struct Node {	int length;	int Num;};struct Grap {	int bIkeNum;	vector <Node> link;};void Dijkstra(Grap * g, int * dis ,vector<int> * PRe ,int N,bool * isvisit ) {	dis[0] = 0;	for (int i = 0; i < N; i++) {		int u = -1, Min = INT_MAX;		for (int j = 0; j < N; j++) { //找Dis最小值			if (!isvisit[j] && dis[j] < Min) {				u = j;				Min = dis[j];			}		}		if (u == -1) return;		isvisit[u] = true;				for (int j = 0; j < g[u].link.size(); j++) {			int v = g[u].link[j].Num;			if (!isvisit[v]) {				if (dis[u] + g[u].link[j].length < dis[v]) {//u是中間結(jié)點(diǎn)					pre[v].clear();					pre[v].push_back(u);					dis[v] = dis[u] + g[u].link[j].length;				}				else if (dis[u] + g[i].link[j].length == dis[v]) {					pre[v].push_back(u);				}			}		}	}}void DFS(vector <int> * pre, vector <int> & patch, vector <int> & tempatch, Grap * g, int & BikeNeed, int & BikeReturn, int v, int Cmax) {	//cout << " v = " << v << endl;	int perfect = Cmax / 2;	if (v == 0) {		tempatch.push_back(v);		int bn = 0, br = 0;		//計(jì)算大小		//cout << "size: " << tempatch.size() << endl;		for (int i = tempatch.size() - 1; i >= 0; i--) {			int b = g[tempatch[i]].bIkeNum;			if (b > perfect) {//大于perfect需要帶走				br += b - perfect;			}			else if (b < perfect){ //補(bǔ)齊				br -= (perfect - b);	//			cout << "br : " << br <<  endl;				if (br < 0) {//不夠補(bǔ)齊 要從中心調(diào)					bn += (-br);					br = 0;				}			}		}		//判斷		if (bn < BikeNeed) {			BikeNeed = bn;			BikeReturn = br;			patch = tempatch;		}		else if (bn == BikeNeed && br < BikeReturn) {			BikeNeed = bn;			BikeReturn = br;			patch = tempatch;		}		tempatch.pop_back();				return;	}	tempatch.push_back(v);	for (int i = 0; i < pre[v].size(); i++) {		DFS(pre, patch, tempatch, g, BikeNeed, BikeReturn, pre[v][i], Cmax);	}	tempatch.pop_back();}int main() {	int Cmax, N, SP, M;	//Cmax最大容量,N站總數(shù),SP問(wèn)題站編號(hào),M道路總數(shù)	cin >> Cmax >> N >> SP >> M;	Grap * g = new Grap[N + 1];	stack <int> s;	for (int i = 1; i <= N; i++) {		cin >> g[i].bIkeNum;	}	g[0].bIkeNum = Cmax / 2;	Node tempNode;	int tempHead, tempTail;	for (int i = 0; i < M; i++) {		cin >> tempHead >> tempTail >> tempNode.length;		tempNode.Num = tempTail;		g[tempHead].link.push_back(tempNode);		//cout << tempHead << " " << tempNode.Num << " " << tempNode.length << endl;		tempNode.Num = tempHead;		g[tempTail].link.push_back(tempNode);		//cout << tempTail << " " << tempNode.Num << " " << tempNode.length << endl;	}//	int MinLegnth = INT_MAX;	bool * isVisit = new bool[N + 1];	int * dis = new int[N + 1];	vector <int> * pre = new vector<int>[N + 1];	for (int i = 0; i <= N; i++) {		dis[i] = INT_MAX;		isVisit[i] = false;	}	Dijkstra(g, dis, pre, N + 1, isVisit);	int BikeNeed = INT_MAX, BikeReturn = INT_MAX;	vector <int> patch, tempatch;	DFS(pre, patch, tempatch, g, BikeNeed, BikeReturn, SP, Cmax);	cout << BikeNeed << " ";	for (int i = patch.size() - 1; i > 0; i--) {		cout << patch[i] << "->";	}	cout << patch[0] << " ";	cout << BikeReturn << endl;	system("pause"); 	return 0;}


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 富蕴县| 拜城县| 锡林浩特市| 日喀则市| 永州市| 茌平县| 延长县| 济南市| 黎川县| 荣成市| 永胜县| 肇州县| 瑞安市| 土默特右旗| 榆林市| 云阳县| 依兰县| 静乐县| 琼结县| 东宁县| 扎鲁特旗| 曲松县| 隆化县| 乐至县| 区。| 海南省| 永德县| 襄樊市| 武夷山市| 湘潭市| 龙游县| 米脂县| 萝北县| 稻城县| 馆陶县| 桓台县| 奉化市| 巨鹿县| 澄迈县| 兰西县| 三门县|