Leetcode - 周赛406

目录

[一,3216. 交换后字典序最小的字符串](#一,3216. 交换后字典序最小的字符串)

[二,3217. 从链表中移除在数组中存在的节点](#二,3217. 从链表中移除在数组中存在的节点)

[三,3218. 切蛋糕的最小总开销 I](#三,3218. 切蛋糕的最小总开销 I)

[四,3219. 切蛋糕的最小总开销 II](#四,3219. 切蛋糕的最小总开销 II)


一,3216. 交换后字典序最小的字符串

本题要求交换一次相邻字符后得到字典序最小的字符串,且要求相邻字符的的奇偶相同,我们可以直接贪心,从左往右查找第一对相邻奇偶相同且左边>右边的字符对,将两者交换就行。

代码如下:

复制代码
class Solution {
    public String getSmallestString(String s) {
        char[] ch = s.toCharArray();
        for(int i=1; i<ch.length; i++){
            if(ch[i-1]>ch[i] && (ch[i]-ch[i-1])%2==0){
                char tmp = ch[i-1];
                ch[i-1] = ch[i];
                ch[i] = tmp;
                break;
            }
        }
        return new String(ch);
    }
}

二,3217. 从链表中移除在数组中存在的节点

本题是一道基础的链表题,不懂链表的可以去看看这篇双向链表详解

代码如下:

复制代码
class Solution {
    public ListNode modifiedList(int[] nums, ListNode head) {
        Set<Integer> set = new HashSet<>();
        for(int x : nums) set.add(x);
        ListNode newHead = new ListNode(0, head);
        ListNode cur = newHead;
        while(cur.next != null){
            if(set.contains(cur.next.val)){
                cur.next = cur.next.next;
            }else{
                cur = cur.next;
            }
        }
        return newHead.next;
    }
}

三,3218. 切蛋糕的最小总开销 I

本题数据范围较小,可以使用dfs来做,可以有这样的四个参数(上端点,下端点,左端点,右端点),定义dfs(l1,r1,l2,r2):为上端点,下端点,左端点,右端点分别为l1,r1,l2,r2时切割成1x1所需要的最小开销。比如我们要在 i 处水平切一刀,那么原问题就会分成上下两个部分,即dfs(l1,i,l2,r2) + dfs(i+1,r1,l2,r2) + h[i],垂直切一刀也是同理。

如图,这里定义l < r:

代码如下:

复制代码
class Solution {
    public int minimumCost(int m, int n, int[] h, int[] v) {
        memo = new int[m][m][n][n];
        for(int i=0; i<m; i++)
            for(int j=0; j<m; j++)
                for(int k=0; k<n; k++)
                    Arrays.fill(memo[i][j][k], -1);
        return dfs(0, m-1, 0, n-1, h, v);
    }
    int[][][][] memo;
    int dfs(int l1, int r1, int l2, int r2, int[] h, int[] v){
        if(l1 == r1 && l2 == r2) return 0;
        if(memo[l1][r1][l2][r2] != -1) return memo[l1][r1][l2][r2];
        int res = Integer.MAX_VALUE;
        for(int i=l1; i<r1; i++){
            res = Math.min(res, dfs(l1, i, l2, r2, h, v) + dfs(i+1, r1, l2, r2, h, v) + h[i]);
        }
        for(int i=l2; i<r2; i++){
            res = Math.min(res, dfs(l1, r1, l2, i, h, v) + dfs(l1, r1, i+1, r2, h, v) + v[i]);
        }
        return memo[l1][r1][l2][r2] = res;
    }
}

四,3219. 切蛋糕的最小总开销 II

本题就不能使用上述做法,会超时,可以使用贪心来做,如图:

代码如下:

复制代码
class Solution {
    public long minimumCost(int m, int n, int[] h, int[] v) {
        Arrays.sort(h);
        Arrays.sort(v);
        int i = m-2, j = n-2;
        int cntH = 1, cntV = 1;
        long ans = 0;
        while(i >= 0 && j >= 0){
            if(v[j] > h[i]){
                ans += cntV*v[j];
                cntH++;
                j--;
            }else{
                ans += cntH*h[i];
                cntV++;
                i--;
            }
        }
        while(i >= 0){
            ans += cntH*h[i];
            i--;
        }
        while(j >= 0){
            ans += cntV*v[j];
            j--;
        }
        return ans;
    }
}
相关推荐
艾醒16 小时前
大模型原理剖析——拆解预训练、微调、奖励建模与强化学习四阶段(以ChatGPT构建流程为例)
算法
冷崖16 小时前
排序--基数排序
c++·算法
F_D_Z16 小时前
哈希表解Two Sum问题
python·算法·leetcode·哈希表
Aaron158817 小时前
基于RFSOC+VU13P+GPU架构在雷达电子战的技术
人工智能·算法·fpga开发·架构·硬件工程·信号处理·基带工程
LYFlied17 小时前
【每日算法】LeetCode124. 二叉树中的最大路径和
数据结构·算法·leetcode·面试·职场和发展
talenteddriver17 小时前
java: Java8以后hashmap扩容后根据高位确定元素新位置
java·算法·哈希算法
yyy(十一月限定版)18 小时前
c语言——栈和队列
java·开发语言·数据结构
跨境猫小妹18 小时前
2025 TikTok Shop:从内容爆发到系统化深耕的商业跃迁
大数据·人工智能·算法·产品运营·亚马逊
不穿格子的程序员18 小时前
从零开始写算法 —— 二叉树篇 1:二叉树的三种遍历(递归实现法)
算法·深度优先·二叉树遍历·fds
子夜江寒18 小时前
逻辑森林与贝叶斯算法简介
算法·机器学习