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;
}