昂贵的聘礼
Time Limit: 1000MS   Memory Limit: 10000K
Total Submissions: 54946   Accepted: 16518

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

Source

思路:因为有等级差限制,所以我们用迪杰斯特拉找最短路的时候可以按照等级差大小为m的区间依次找过去,找到所有点的最短路中值最小的那个
代码:

#include<cstdio>
#include<cstring>
#include<vector>
#define ll long long
using namespace std;
ll n,m;
struct st{
ll w;
ll i;
};
struct{
vector<st> v;
ll l;
}s[110];
ll min(ll a,ll b){
if(a>b)
return b;
return a;
}
ll check(ll a,ll b){
if(a>=b)
return a>(b+m);
return 1;
}
ll dis[110],vt[110];
ll dp[110];
ll mn1;
ll djstl(ll k){
ll i,j,p;
ll mn;
for(i=1;i<=n;i++)
dp[i]=1e9;
dp[1]=0;//dis[1];
for(i=1;i<=n;i++){
vt[k]=1;
mn=1e9;
for(j=0;j<s[k].v.size();j++){
if(!vt[s[k].v[j].i])
dp[s[k].v[j].i]=min(dp[s[k].v[j].i],dp[k]+s[k].v[j].w);//min(dp[s[k].v[j].i],dp[k]-dis[k]+s[k].v[j].w+dis[s[k].v[j].i]);
}//如果用注释后的代码做的话普通的测试数据都可以得出正确答案,但是一旦用这组数据就错了
/*4 4
50000 4 2
2 10
3 10
1000 4 1
4 3
100 4 1
4 10
10 4 0 23*/
//因为我们要找的是一条最短路,每次应该通过边的值(而不能直接加上当前点的值)来更新当前的dp数组(到每个点的最短距离)
//(不能加上当前点的基础价格来更新(因为我们可以通过交易其他的物品来减少当前物品的花费,
//所以如果你直接加上当前点的基础价格就不能保证每次找的都是当前最短的的那条路的终点)
for(p=1;p<=n;p++){
if(!vt[p]&&(mn>dp[p])){
mn=dp[p];
k=p;
}
}
if(mn==1e9)
break;
}
for(i=1;i<=n;i++)
if(mn1>dp[i]+dis[i])//最后才加上终点的基础价格
mn1=dp[i]+dis[i];//dp[i];
return 0;
}
int main(){
ll i,j;
ll x;
ll b,c;
c=0;
st a;
scanf("%lld%lld",&m,&n);
for(i=1;i<=n;i++){
scanf("%lld%lld%lld",&dis[i],&s[i].l,&x);
for(j=0;j<x;j++){
scanf("%lld%lld",&a.i,&a.w);
s[i].v.push_back(a);
}
}
/*
for(i=1;i<=n;i++){
for(j=0;j<s[i].v.size();j++)
if(s[i].l>s[s[i].v[j].i].l+m)
s[i].v.erase(s[i].v.begin()+j);
}*/
mn1=1e9;
for(i=s[1].l-m;i<=s[1].l;i++){
memset(vt,0,sizeof(vt));
for(j=1;j<=n;j++){
if(check(s[j].l,i))//将区间外的点直接标记为1
vt[j]=1;
//else //prllf("%d ",j);
}
//prllf("\n");
djstl(1);
}
printf("%lld\n",mn1);
return 0;
}

  

poj1062(分区间迪杰斯特拉,内含测试数据,一直wa的同学可以进来看看)的更多相关文章

  1. 1018 Public Bike Management (30分) (迪杰斯特拉+dfs)

    思路就是dijkstra找出最短路,dfs比较每一个最短路. dijkstra可以找出每个点的前一个点, 所以dfs搜索比较的时候怎么处理携带和带走的数量就是关键,考虑到这个携带和带走和路径顺序有关, ...

  2. C++迪杰斯特拉算法求最短路径

    一:算法历史 迪杰斯特拉算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向图中最短路径问题.迪杰斯特拉算法主要特点是以 ...

  3. 【算法杂谈】LJX的迪杰斯特拉算法报告

    迪杰斯特拉(di jie qi)算法 这里有一张图: 假设要求从1号节点到5号节点的最短路.那么根据迪杰斯特拉算法的思想,我们先看: 节点1,从节点1出发的一共有3条路,分别是1-6.1-3.1-2. ...

  4. HDU6166-Senior Pan-Dijkstra迪杰斯特拉算法(添加超源点,超汇点)+二进制划分集合-2017多校Team09

    学长好久之前讲的,本来好久好久之前就要写题解的,一直都没写,懒死_(:з」∠)_ Senior Pan Time Limit: 12000/6000 MS (Java/Others)    Memor ...

  5. pat1003 迪杰斯特拉法和dfs求最短路

    本题的背景是求定点和定点之间的最短路问题(所有的最短路 不是一个解  是全部解,方法手段来自数据结构课程中的迪杰斯特拉算法和dfs(深度优先遍历). 分别用两种方法编程如下代码 dfs #includ ...

  6. PAT 1087 All Roads Lead to Rome[图论][迪杰斯特拉+dfs]

    1087 All Roads Lead to Rome (30)(30 分) Indeed there are many different tourist routes from our city ...

  7. 说说关于洛谷P4779迪杰斯特拉的堆优化

    众所周知,这题必须要用堆优化的迪杰斯特拉的堆优化才能过,否则60分(错失一等奖) 我没有得过一等奖但还是要说: P4779 全过程: struct node//堆中的比较函数 { int dis; i ...

  8. Poj 3268 Silver cow party 迪杰斯特拉+反向矩阵

    Silver cow party 迪杰斯特拉+反向 题意 有n个农场,编号1到n,每个农场都有一头牛.他们想要举行一个party,其他牛到要一个定好的农场中去.每个农场之间有路相连,但是这个路是单向的 ...

  9. bfs输出路径 && 最短路(迪杰斯特拉)输出路径

    问题描述 解决方法 1.像第一个问题那就是最短路问题(我代码采用迪杰斯特拉算法)实现 2.换乘次数最少,那就用bfs广搜来寻找答案.但是我的代码不能保证这个最少换乘是最短路程 代码 1 #includ ...

随机推荐

  1. 反射API(一)

    <?php function classData(ReflectionClass $class) { echo '<hr>'; $details = '当前文件:'; $detail ...

  2. python-flask-session和scoped_session区别

    scoped_session from sqlalchemy.orm import sessionmaker from sqlalchemy import create_engine from sql ...

  3. json加密

    有的时候我们为了传参数的URL比较安全,我们一般会用json加密的方法来使自己的URL安全. $a['order_sn'] = $orderNo;$data = json_encode( $a);$d ...

  4. Visual studio 利用Nuget 控制台安装已经下载好的插件

    利用Nuget 控制台安装已经下载好的插件 1 打开控制台 Tools > Library Package Manager > Package Manager Console 2 设置pa ...

  5. git status 查看当前修改文件

    可以查看当前已经修改的文件.

  6. Linux下切换使用两个版本的JDK

    Linux下切换使用两个版本的JDK 我这里原来已经配置好过一个1.7版本的jdk. 输出命令: java -version [root@hu-hadoop1 sbin]# java -version ...

  7. Python学习之路【第二篇】-pyc简介、Python常用的数据类型及其用法和常用运算符

    1.pyc简介 python程序在运行时也有编译过程,编译后会产生.pyc文件.这是一种由python虚拟机执行的二进制文件(字节码),用于保存内存中PyCodeObject,以便加快程序的加载运行. ...

  8. OllyDbg安装教程

    1.下载 http://tools.pediy.com/windows/debuggers.htm 我们这里选择OllyDbg1.10下载 2.安装 解压下载的压缩包直接双击启动即可使用 3.插件安装 ...

  9. URL to load resources from the classpath in Java

    In Java, you can load all kinds of resources using the same API but with different URL protocols: fi ...

  10. C# 中web如何定时同步数据

    之前做定时器同步方法试过很多方法, 不过都有些问题 1)quartz + IIS 方式(web项目发布到IIS上,出现IIS应用池回收问题) 2)用线程Timer方式 (出现多个线程同步同个任务问题) ...