Leetcode3256. 放三个车的价值之和最大 I

Every day a Leetcode

题目来源:3256. 放三个车的价值之和最大 I

解法1:贪心

从大到下排序矩阵所有值, 记为数组v。

转化此题:从r*c个数中选取3个数分别给到车1,车2,和车3,使得符合条件的三数之和最大。

结论:可选前2r+2c+1个最大值作为候选值,在此范围枚举求三数之和最大。

代码:

cpp 复制代码
/*
 * @lc app=leetcode.cn id=3256 lang=cpp
 *
 * [3256] 放三个车的价值之和最大 I
 */

// @lc code=start
class Solution
{
public:
    long long maximumValueSum(vector<vector<int>> &board)
    {
        int m = board.size(), n = m ? board[0].size() : 0;
        vector<tuple<int, int, int>> v;
        for (int i = 0; i < m; i++)
            for (int j = 0; j < n; j++)
                v.push_back({board[i][j], i, j});
        sort(v.begin(), v.end(), greater<tuple<int, int, int>>());

        long long ans = LONG_LONG_MIN;
        int range = min(2 * (m + n) + 1, (int)v.size());
        for (int i = 0; i < range; i++)
        {
            auto [v1, x1, y1] = v[i];
            for (int j = i + 1; j < range; j++)
            {
                auto [v2, x2, y2] = v[j];
                if (x2 == x1 || y2 == y1)
                    continue;
                for (int k = j + 1; k < range; k++)
                {
                    auto [v3, x3, y3] = v[k];
                    if (x3 == x1 || y3 == y1 || x3 == x2 || y3 == y2)
                        continue;
                    ans = max(ans, (long long)v1 + v2 + v3);
                }
            }
        }
        return ans;
    }
};
// @lc code=end

结果:

复杂度分析:

时间复杂度:O((m+n)3),其中 m 和 n 分别是数组 board 的行数和列数。

空间复杂度:O(m * n),其中 m 和 n 分别是数组 board 的行数和列数。

相关推荐
点云SLAM16 小时前
Boost库中Boost.PropertyTree使用和实战示例
开发语言·c++·josn·boost库·参数读取
晨非辰16 小时前
【数据结构】排序详解:从快速排序分区逻辑,到携手冒泡排序的算法效率深度评测
运维·数据结构·c++·人工智能·后端·深度学习·排序算法
草莓熊Lotso17 小时前
C++ 二叉搜索树(BST)完全指南:从概念原理、核心操作到底层实现
java·运维·开发语言·c++·人工智能·经验分享·c++进阶
海琴烟Sunshine19 小时前
leetcode 383. 赎金信 python
python·算法·leetcode
上去我就QWER1 天前
Qt快捷键“魔法师”:QKeySequence
开发语言·c++·qt
将编程培养成爱好1 天前
C++ 设计模式《外卖骑手状态系统》
c++·ui·设计模式·状态模式
猿太极1 天前
设计模式学习(3)-行为型模式
c++·设计模式
cynicme1 天前
力扣3228——将 1 移动到末尾的最大操作次数
算法·leetcode
熬了夜的程序员1 天前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
随意起个昵称1 天前
【递归】二进制字符串中的第K位
c++·算法