luogu1359 租用游艇

Posted wx62f0894128448

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了luogu1359 租用游艇相关的知识,希望对你有一定的参考价值。


​http://www.elijahqi.win/archives/1614​​​
题目描述
长江游艇俱乐部在长江上设置了n 个游艇出租站1,2,…,n。游客可在这些游艇出租站租用游艇,并在下游的任何一个游艇出租站归还游艇。游艇出租站i 到游艇出租站j 之间的租金为r(i,j),1<=i<=j<=n。试设计一个算法,计算出从游艇出租站1 到游艇出租站n 所需的最少租金。

对于给定的游艇出租站i 到游艇出租站j 之间的租金为r(i,j),1<=i< j<=n,编程计算从游艇出租站1 到游艇出租站n所需的最少租金。

保证计算过程中任何时刻数值都不超过10^6

输入输出格式
输入格式:

由文件提供输入数据。文件的第1 行中有1 个正整数n(n<=200),表示有n个游艇出租站。接下来的n-1 行是一个半矩阵r(i,j),1<=i< j<=n。

输出格式:

程序运行结束时,将计算出的从游艇出租站1 到游艇出租站n所需的最少租金输出到文件中。

输入输出样例
输入样例#1: 复制

3
5 15
7

输出样例#1: 复制

12
带着学弟写题
自己傻逼的写成了最长路 忘了写greater 贡献了两发wa 果然自己还是一只弱鸡啊

#include<cstdio>
#include<queue>
#define N 220
#include<cstring>
#include<vector>
#define pa pair<int,int>
using namespace std;
inline char gc()
static char now[1<<16],*S,*T;
if (T==S)T=(S=now)+fread(now,1,1<<16,stdin);if (T==S) return EOF;
return *S++;

inline int read()
int x=0;char ch=gc();
while (ch<0||ch>9) ch=gc();
while (ch<=9&&ch>=0)x=x*10+ch-0;ch=gc();
return x;

struct node
int y,z,next;
data[166000];
int h[N],flag[N],num,n,f[N];
void dijkstra()
priority_queue<pa,vector<pa>,greater<pa> > q;memset(f,0x3f,sizeof(f));f[1]=0;q.push(make_pair(0,1));
while(!q.empty())
int x=q.top().second;q.pop();if (flag[x]) continue;flag[x]=1;
for (int i=h[x];i;i=data[i].next)
int y=data[i].y,z=data[i].z;
if (f[x]+z<f[y])
f[y]=f[x]+z;q.push(make_pair(f[y],y));




int main()
// freopen("1359.in","r",stdin);
n=read();
for (int i=1;i<n;++i)
for (int j=i+1;j<=n;++j)
int z=read();
data[++num].y=j;data[num].z=z;data[num].next=h[i];h[i]=num;

dijkstra();
printf("%d",f[n]);
return 0;


以上是关于luogu1359 租用游艇的主要内容,如果未能解决你的问题,请参考以下文章

洛谷 P1359 租用游艇dp

租用游艇

P1359 租用游艇

洛谷 P1359 租用游艇

洛谷 P1359 租用游艇

P1359 租用游艇