【题解】NC219035 春游(模拟 - 分情况讨论)

https://ac.nowcoder.com/acm/problem/219035

cpp 复制代码
#include <iostream>

using namespace std;
long long typedef LL;

LL fun(LL n, LL a, LL b) {
    if (n <= 2) return min(a, b);
    
    LL ret = 0;
    
    if (a * 3 < b * 2) // 尽可能选择双人船 
    {
        ret += n / 2 * a;
        n %= 2;
        if(n) ret += min(min(a, b), b - a);
    }
    else // 尽可能选择三人船
    {
        ret += n / 3 * b;
        n %= 3;
        if (n == 1) ret += min(min(a, b), 2*a - b);
        else if (n == 2) ret += min(min(a, b), 3*a - b);
    }
    return ret;
}

int main()
{
    int t;
    cin >> t;
    while (t--) {
        LL n, a, b;
        cin >> n >> a >> b;
        cout << fun(n, a, b) << endl;
    }
    
    return 0;
}
相关推荐
南境十里·墨染春水7 分钟前
C++ 笔记 深赋值 浅赋值(面向对象)
开发语言·jvm·c++·笔记
旺仔.29111 分钟前
常用算法 详解
数据结构·算法
今儿敲了吗15 分钟前
算法复盘——差分
数据结构·c++·笔记·学习·算法
qq_3985865425 分钟前
平衡三进制超前进位加法器
算法
西西弟29 分钟前
最短路径之Dijkstra算法(数据结构)
数据结构·算法
沉鱼.4433 分钟前
树形DP题目
算法·深度优先
VelinX1 小时前
【个人学习||算法】多维动态规划
学习·算法·动态规划
AlenTech1 小时前
139. 单词拆分 - 力扣(LeetCode)
算法·leetcode·职场和发展
郭涤生1 小时前
std::async 和 std::future的使用
c++
墨韵流芳1 小时前
CCF-CSP第41次认证第一题——平衡数
c++·算法·ccf·平衡数