力扣 第 341 场周赛代码---50minAK

T1 一最多的行

class Solution {
public:
    vector<int> rowAndMaximumOnes(vector<vector<int>>& g) {
        int n = g.size(), m = g[0].size();
        int res = 0, row = 0;
        for(int i = 0; i < n; i ++)
        {
            int sum = 0;
            for(int j = 0; j < m; j ++)
                sum += g[i][j] == 1;
            if(sum > res) 
            {
                res = sum;
                row = i;
            }
        }
        return {row, res};
    }
};

T2 找出可整除性得分最大的整数 — 模拟

class Solution {
public:
    int maxDivScore(vector<int>& a, vector<int>& b) {
        int maxv = 0, ans = 2e9;
        for(auto x : b)
        {
            int sum = 0;
            for(auto v : a)
                if(v % x == 0) sum ++;
            if(sum > maxv)
            {
                maxv = sum;
                ans = x;
            }
            else if(sum == maxv) ans = min(ans, x);
        }
        return ans;
    }
};

T3 构造有效字符串的最少插入数 — 贪心

class Solution {
public:
    int addMinimum(string s) {
        int res = 1;
        for(int i = 1; i < s.size(); i ++)
            if(s[i] <= s[i - 1]) res ++;
        res = 3 * res - s.size();
        return res;
    }
};

T4 最小化旅行的价格总和 — 暴搜 + 树形dp

class Solution {
public:
    vector<int> g[210];
    int f[200][2] = {0};
    int minimumTotalPrice(int n, vector<vector<int>>& edges, vector<int>& price, vector<vector<int>>& trips) {

        vector<int> w = price;
        vector<int> cnt(200, 0);
        for(auto &e : edges)
        {
            g[e[0]].push_back(e[1]);
            g[e[1]].push_back(e[0]);
        }
        
        function<void(int, int, int, vector<int>)> get_value = [&](int u, int fa, int ed, vector<int> path)
        {
            if(u == ed)
            {
                for(auto x : path) cnt[x] ++;
                return ;
            }
            for(auto v : g[u])
            {
                if(v == fa) continue;
                path.push_back(v);
                get_value(v, u, ed, path);
                path.pop_back();
            }
    	};
        
        for(auto &e : trips)
            get_value(e[0], -1, e[1], {e[0]});
        
        int sum = 0;
        for(int i = 0; i < n; i ++) w[i] = price[i] * cnt[i], sum += w[i];
        
        function<void(int,int)> dfs = [&](int u,int fa)
        {
            f[u][1] = w[u];
            for(auto v : g[u])
            {
                if(fa == v) continue;
                dfs(v, u);
                f[u][0] += max(f[v][0], f[v][1]);
                f[u][1] += f[v][0];
            }
    	};
        
        dfs(0, -1);
        int res = sum - max(f[0][0], f[0][1]) / 2;
        
        return res;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_WAWA鱼_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值