【题解】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;
}
相关推荐
知无不研2 分钟前
c++垃圾回收机制
开发语言·c++·智能指针·raii·垃圾回收机制
luckycoding4 分钟前
1487. 保证文件名唯一
数据结构·算法·leetcode
DeeGLMath9 分钟前
从基础算法到机器学习的研究轨迹
人工智能·算法·机器学习
Barkamin13 分钟前
冒泡排序的简单实现
java·算法·排序算法
_dindong13 分钟前
【单调栈/队列&并查集&字符串哈希&Tire树】习题集锦
数据结构·c++·算法·哈希算法
西装没钱买16 分钟前
QT组播的建立和使用(绑定特定的网卡,绑定特定IP)
网络·c++·qt·udp·udp组播
独自破碎E23 分钟前
【手撕真题】合并区间
算法
big_rabbit050224 分钟前
[算法][力扣110]平衡二叉树
数据结构·算法·leetcode
二年级程序员32 分钟前
排序(五)“计数排序” 与 “各排序实际用时测量”
c语言·算法·排序算法
Ralph_Y36 分钟前
C++:static
开发语言·c++