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

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

昂貴的聘禮 [DFS][最短路]

2019-11-08 01:36:01
字體:
來源:轉載
供稿:網友

Description

年輕的探險家來到了一個印第安部落里。在那里他和酋長的女兒相愛了,于是便向酋長去求親。酋長要他用10000個金幣作為聘禮才答應把女兒嫁給他。探險家拿不出這么多金幣,便請求酋長降低要求。酋長說:”嗯,如果你能夠替我弄到大祭司的皮襖,我可以只要8000金幣。如果你能夠弄來他的水晶球,那么只要5000金幣就行了。”探險家就跑到大祭司那里,向他要求皮襖或水晶球,大祭司要他用金幣來換,或者替他弄來其他的東西,他可以降低價格。探險家于是又跑到其他地方,其他人也提出了類似的要求,或者直接用金幣換,或者找到其他東西就可以降低價格。不過探險家沒必要用多樣東西去換一樣東西,因為不會得到更低的價格。探險家現在很需要你的幫忙,讓他用最少的金幣娶到自己的心上人。另外他要告訴你的是,在這個部落里,等級觀念十分森嚴。地位差距超過一定限制的兩個人之間不會進行任何形式的直接接觸,包括交易。他是一個外來人,所以可以不受這些限制。但是如果他和某個地位較低的人進行了交易,地位較高的的人不會再和他交易,他們認為這樣等于是間接接觸,反過來也一樣。因此你需要在考慮所有的情況以后給他提供一個最好的方案。 為了方便起見,我們把所有的物品從1開始進行編號,酋長的允諾也看作一個物品,并且編號總是1。每個物品都有對應的價格P,主人的地位等級L,以及一系列的替代品Ti和該替代品所對應的”優惠”Vi。如果兩人地位等級差距超過了M,就不能”間接交易”。你必須根據這些數據來計算出探險家最少需要多少金幣才能娶到酋長的女兒。 Input

輸入第一行是兩個整數M,N(1 <= N <= 100),依次表示地位等級差距限制和物品的總數。接下來按照編號從小到大依次給出了N個物品的描述。每個物品的描述開頭是三個非負整數P、L、X(X < N),依次表示該物品的價格、主人的地位等級和替代品總數。接下來X行每行包括兩個整數T和V,分別表示替代品的編號和”優惠價格”。 Output

輸出最少需要的金幣數。 Sample Input

1 4 10000 3 2 2 8000 3 5000 1000 2 1 4 200 3000 2 1 4 200 50 2 0 Sample Output

5250

題解

等價限制是一個全局限制,即你所選的任意兩點都不能超過差值

DFS解法

#include <stdio.h>#include <string.h>#include <vector>#include <queue>#include <algorithm>#define MAX_N 102#define INF 0x3f3f3f3fusing namespace std;struct node{int p,l;}res[MAX_N];int m,n,x,best;vector<pair<int,int> > G[MAX_N];bool vis[MAX_N];void dfs(int cnt,int now,int minrank,int maxrank){ if(cnt==n||now>best) return ; else if(now+res[cnt].p<best) best=now+res[cnt].p; for(int i=0;i<G[cnt].size();i++){ int to=G[cnt][i].first,cost=G[cnt][i].second; int d1=minrank-res[to].l; int d2=maxrank-res[to].l; int d3=res[cnt].l-res[to].l; if(!vis[to]&&-m<=d1&&d1<=m&&-m<=d2&&d2<=m&&-m<=d3&&d3<=m){ vis[to]=true; dfs(to,now+cost,min(minrank,res[to].l),max(maxrank,res[to].l)); vis[to]=false; } }}int main(){ scanf("%d%d",&m,&n); for(int i=0;i<n;i++){ scanf("%d%d%d",&res[i].p,&res[i].l,&x); for(int j=0;j<x;j++){ int to,cost; scanf("%d%d",&to,&cost);to--; G[i].push_back(make_pair(to,cost)); } } best=INF;vis[0]=true; dfs(0,0,res[0].l,res[0].l);
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安顺市| 福建省| 祥云县| 景泰县| 兴义市| 古交市| 潼南县| 海宁市| 巫山县| 渑池县| 舟曲县| 门源| 乌兰浩特市| 宝鸡市| 呼伦贝尔市| 海阳市| 东至县| 黑河市| 右玉县| 北流市| 响水县| 汽车| 陇西县| 内丘县| 威远县| 旌德县| 天等县| 南皮县| 邹城市| 革吉县| 繁峙县| 莆田市| 星子县| 禹州市| 剑川县| 富宁县| 平度市| 磐石市| 威信县| 济阳县| 西林县|