麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

1018. Public Bike Management 解析

2019-11-14 13:08:27
字體:
來源:轉載
供稿:網友

單用Dijstra算法比較難維護。用Dijstra+DFS能簡化不少。

看到有小伙伴例7有問題,可以看下是不是Dijstra的算法在計算路徑的時候出問題沒。我的就是下標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是中間結點					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;		//計算大小		//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){ //補齊				br -= (perfect - b);	//			cout << "br : " << br <<  endl;				if (br < 0) {//不夠補齊 要從中心調					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站總數,SP問題站編號,M道路總數	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;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 在线观看免费视频麻豆 | 中国av免费观看 | 久久精品毛片 | 亚洲精品一区二区三区大胸 | 日本a∨精品中文字幕在线 欧美1—12sexvideos | 欧美三级一级 | 久久人 | 成人激情在线观看 | 国产青草视频在线观看 | 成人精品 | 97porn| 一级毛片特黄 | 久草在线资源观看 | 羞羞的视频免费 | 欧美一级成人一区二区三区 | 国产91九色 | 国产成人av在线播放 | 国产午夜精品视频免费不卡69堂 | 亚洲第一综合色 | 久久免费精品 | 中国杭州少妇xxxx做受 | 欧美黄色免费视频 | 成人免费一区二区三区在线观看 | 久久91精品国产91久久yfo | 免费久久精品 | 免费久久久 | 性片免费看 | 87成人免费看片 | 日本中文高清 | 九色激情网 | 媚药按摩痉挛w中文字幕 | 久久精品免费国产 | 免费毛片免费看 | www.69色| 美女污污视频在线观看 | 毛片免费观看视频 | 日日操夜夜透 | 久久国产亚洲精品 | 午夜精品久久久久久久爽 | 国产午夜亚洲精品 | 国产在线久 |