首页 > 代码库 > 洛谷 P1359 租用游艇

洛谷 P1359 租用游艇

题目描述

长江游艇俱乐部在长江上设置了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

刚开始未读懂题目,只是因为题目描述的r数组,不过这道题还是挺简单的
 1 #include<iostream>
 2 #include<cstdio>
 3 
 4 using namespace std;
 5 
 6 int m[201][201],p[201],n;
 7 
 8 int main() 
 9 {
10     memset(p,127,sizeof(p));
11     scanf("%d",&n);
12     for(int i=1; i<=n; i++)
13     {
14         for(int j=i+1; j<=n; j++)
15         {
16             scanf("%d",&m[i][j]);
17         }    
18     }    
19     p[1]=0;
20     for(int i=2; i<=n; i++)
21     {
22         for(int j=1; j<i; j++)
23         {
24             p[i]=min(p[i],p[j]+m[j][i]);
25         }    
26     }    
27     printf("%d",p[n]);
28     
29     return 0;
30 }

 

洛谷 P1359 租用游艇