poj1062(分区间迪杰斯特拉,内含测试数据,一直wa的同学可以进来看看)
Time Limit: 1000MS | Memory Limit: 10000K | |
Total Submissions: 54946 | Accepted: 16518 |
Description
为了方便起见,我们把所有的物品从1开始进行编号,酋长的允诺也看作一个物品,并且编号总是1。每个物品都有对应的价格P,主人的地位等级L,以及一系列的替代品Ti和该替代品所对应的"优惠"Vi。如果两人地位等级差距超过了M,就不能"间接交易"。你必须根据这些数据来计算出探险家最少需要多少金币才能娶到酋长的女儿。
Input
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
#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的同学可以进来看看)的更多相关文章
- 1018 Public Bike Management (30分) (迪杰斯特拉+dfs)
思路就是dijkstra找出最短路,dfs比较每一个最短路. dijkstra可以找出每个点的前一个点, 所以dfs搜索比较的时候怎么处理携带和带走的数量就是关键,考虑到这个携带和带走和路径顺序有关, ...
- C++迪杰斯特拉算法求最短路径
一:算法历史 迪杰斯特拉算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向图中最短路径问题.迪杰斯特拉算法主要特点是以 ...
- 【算法杂谈】LJX的迪杰斯特拉算法报告
迪杰斯特拉(di jie qi)算法 这里有一张图: 假设要求从1号节点到5号节点的最短路.那么根据迪杰斯特拉算法的思想,我们先看: 节点1,从节点1出发的一共有3条路,分别是1-6.1-3.1-2. ...
- HDU6166-Senior Pan-Dijkstra迪杰斯特拉算法(添加超源点,超汇点)+二进制划分集合-2017多校Team09
学长好久之前讲的,本来好久好久之前就要写题解的,一直都没写,懒死_(:з」∠)_ Senior Pan Time Limit: 12000/6000 MS (Java/Others) Memor ...
- pat1003 迪杰斯特拉法和dfs求最短路
本题的背景是求定点和定点之间的最短路问题(所有的最短路 不是一个解 是全部解,方法手段来自数据结构课程中的迪杰斯特拉算法和dfs(深度优先遍历). 分别用两种方法编程如下代码 dfs #includ ...
- 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 ...
- 说说关于洛谷P4779迪杰斯特拉的堆优化
众所周知,这题必须要用堆优化的迪杰斯特拉的堆优化才能过,否则60分(错失一等奖) 我没有得过一等奖但还是要说: P4779 全过程: struct node//堆中的比较函数 { int dis; i ...
- Poj 3268 Silver cow party 迪杰斯特拉+反向矩阵
Silver cow party 迪杰斯特拉+反向 题意 有n个农场,编号1到n,每个农场都有一头牛.他们想要举行一个party,其他牛到要一个定好的农场中去.每个农场之间有路相连,但是这个路是单向的 ...
- bfs输出路径 && 最短路(迪杰斯特拉)输出路径
问题描述 解决方法 1.像第一个问题那就是最短路问题(我代码采用迪杰斯特拉算法)实现 2.换乘次数最少,那就用bfs广搜来寻找答案.但是我的代码不能保证这个最少换乘是最短路程 代码 1 #includ ...
随机推荐
- 微信小程序选择图片,查看图片信息,浏览图片,图片上传
依次点击链接请查看以下步骤 选择图片: https://mp.weixin.qq.com/debug/wxadoc/dev/api/media-picture.html#wxchooseimageob ...
- Mysql中从一张表中的数据添加到另一张表
A为原表 B为要加入的表$sql="insert into B select * from A where id=$id";
- python基础之函数参数,名称空间,以及函数嵌套
函数进阶内容梗概: 1. 函数参数--动态传参 2. 名称空间, 局部名称空间, 全局名称空间, 作⽤用域, 加载顺序. 3. 函数的嵌套 4. gloabal , nonlocal 关键字 1. 函 ...
- Card Game Again CodeForces - 818E (双指针)
大意: 给定序列, 求多少个区间积被k整除. 整除信息满足单调性, 显然双指针. 具体实现只需要考虑k的素数向量, 对每一维维护个指针即可. 这题看了下cf其他人的做法, 发现可以直接暴力, 若当前的 ...
- python记录_day18 反射 判断函数与方法
一.三个内置函数 1.issubclass(a, b) 判断a类是否是b类的子类 class Foo: pass class Zi(Foo): pass class Sun(Zi): pass pr ...
- spring boot(八)RabbitMQ使用
RabbitMQ 即一个消息队列,主要是用来实现应用程序的异步和解耦,同时也能起到消息缓冲,消息分发的作用. 消息中间件在互联网公司的使用中越来越多,刚才还看到新闻阿里将RocketMQ捐献给了apa ...
- 关于react16.4——错误边界
过去,组件内的 JavaScript 错误常常会破坏 React 内部状态,并导致它在下一次渲染时产生神秘的错误.这些错误总会在应用代码中较早的错误引发的,但 React 并没有提供一种方式能够在组件 ...
- 关于移动端rem适配
var num = 1 / window.devicePixelRatio; var fontSize = document.documentElement.clientWidth / 10; doc ...
- Version Control System
Version Control System(版本控制系统),是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统.版本控制系统不仅可以应用于软件源代码的文本文件,而且可以对任何类型 ...
- InnoDB存储引擎介绍-(1)InnoDB存储引擎结构
首先以一张图简单展示 InnoDB 的存储引擎的体系架构. 从图中可见, InnoDB 存储引擎有多个内存块,这些内存块组成了一个大的内存池,主要负责如下工作: 维护所有进程/线程需要访问的多个内部数 ...