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 的行数和列数。

相关推荐
黄卷青灯772 分钟前
c++ vector类 和 eigen库 处理向量的区别 列出代码举例
开发语言·c++·vector·eigen
深夜吞食6 分钟前
项目实现:云备份③(配置文件加载模块、数据管理模块的实现)
linux·c语言·c++·json
cwywsx7 分钟前
C++:二叉搜索树
开发语言·c++·算法
小米里的大麦21 分钟前
【C++】深入理解作用域和命名空间:从基础到进阶详解
c++·笔记·作用域·命名空间
Lenyiin23 分钟前
3286、穿越网格图的安全路径
c++·算法·leetcode
小丑西瓜66627 分钟前
c++智能指针
开发语言·c++·学习·基础语法·智能指针
螺蛳粉只吃炸蛋的走风30 分钟前
面试题总结(三) -- 内存管理篇
c语言·c++·面试·内存·堆栈·raii
Daking-1 小时前
「数组」十大排序:精讲与分析(C++)
c++·算法·排序算法
轩源源1 小时前
C/C++内存管理
c语言·开发语言·数据结构·c++·算法·缓存·内存空间的开创
程序员黄老师1 小时前
Windows与Linux下 SDL2的第一个窗口程序
c++·windows·ffmpeg·sdl