洛谷 P1359 租用游艇

题目链接

P1359 租用游艇 普及

题目描述

长江游艇俱乐部在长江上设置了 n n n 个游艇出租站 1 , 2 , 3 , . . . , n 1,2,3,...,n 1,2,3,...,n,游客可在这些游艇出租站租用游艇,并在下游的任何一个游艇出租站归还游艇。游艇出租站 i i i 到游艇出租站 j j j 之间的租金为 r ( i , j ) ( 1 ≤ i ≤ j ≤ n ) r(i,j) \quad (1 \leq i \leq j \leq n) r(i,j)(1≤i≤j≤n) 。

请计算出从 出租站 1 1 1 到 出租站 n n n 所需的最少租金。

输入格式

第一行中有一个正整数 n n n ,表示有 n n n 个游艇出租站。

接下来的 n − 1 n - 1 n−1 行是一个半矩阵 r ( i , j ) ( 1 ≤ i ≤ j ≤ n ) r(i,j) \quad (1 \leq i \leq j \leq n) r(i,j)(1≤i≤j≤n)。

输入格式

输出计算出的从游艇出租站 1 1 1 到游艇出租站 n n n 所需的最少租金

数据范围

n ≤ 200 n≤200 n≤200,保证计算过程中任何时刻数值都不超过 1 0 6 10^6 106 。

示例1:

输入:

3

5 15

7

输出:

12

解法:贪心

我们定义邻接矩阵 g g g, g i j gij gij 记录的是 出租站 i i i 到 出租站 j j j 的距离。

我们定义 f i fi fi 表示从 出租站 1 1 1 到 出租站 i i i 所需要的最小租金。按照定义,我们最终返回的答案就是 f n fn fn

我们可以得出如下状态转移方程:

f i = m i n { f i , f j + g j i } ( 1 ≤ j < i ) fi = min \{ fi , fj + gji \} \quad (1 \leq j < i) fi=min{fi,fj+gji}(1≤j<i)

时间复杂度: O ( n 2 ) O(n^2) O(n2)

C++代码:

cpp 复制代码
#include<iostream>
#include<vector>

using namespace std;

const int N = 210;
int g[N][N];

void solve(){
    int n;
    cin>>n;
    for(int i = 1;i < n;i++){
        for(int j = i + 1;j <= n;j++){
            cin>>g[i][j];
        }
    }
    
    vector<int> f(n + 1 , 1e9);
    
    f[1] = 0;
    
    for(int i = 2;i <= n;i++){
        for(int j = 1;j < i;j++) f[i] = min(f[i] , f[j] + g[j][i]);
    }
    
    cout<<f[n]<<'\n';
}

int main(){
    solve();
    return 0;
}
相关推荐
青山师9 小时前
动态规划算法深度解析:从状态转移方程到工业级优化
数据结构·算法·面试·动态规划·代理模式·java面试
月光船幽幽12 小时前
Helio-Core临界控制:守护拓扑量子稳定
人工智能·科技·动态规划·拓扑学
菜菜的顾清寒17 小时前
力扣HOT100(41)动态规划-杨辉三角
算法·leetcode·动态规划
菜菜的顾清寒18 小时前
HOT100力扣(40) 动态规划-爬楼梯
算法·leetcode·动态规划
workflower18 小时前
具身智能-三层结构
人工智能·设计模式·动态规划·软件工程·scrum
一只老丸19 小时前
HOT100题打卡第27天——动态规划(hard)
算法·动态规划
如竟没有火炬1 天前
乘法表中第K小的数——二分
开发语言·数据结构·python·算法·leetcode·职场和发展·动态规划
月光船幽幽1 天前
LLM智能网关配置解析
人工智能·科技·动态规划·拓扑学
月光船幽幽2 天前
四层门禁+自愈机制
人工智能·科技·动态规划·拓扑学
洛水水3 天前
【力扣100题】55.编辑距离
算法·leetcode·动态规划