Leetcode - 周赛392

目录

一,3105. 最长的严格递增或递减子数组

二,3106. 满足距离约束且字典序最小的字符串

三,3107. 使数组中位数等于 K 的最少操作数

四,3108. 带权图里旅途的最小代价


一,3105. 最长的严格递增或递减子数组

本题求最长递增/递减的子数组长度(严格递增/递减 即不能相等),可以先遍历数组求出最长递增子数组,再遍历一边求出最长递减子数组,返回两者的最大值,代码如下:

class Solution {
    public int longestMonotonicSubarray(int[] nums) {
        int ans = 1;
        int n = nums.length;
        boolean flg = false;
        for(int l=0,r=1; r<n; r++){
            if(nums[r]-nums[r-1]>0){//递增
                ans = Math.max(ans, r-l+1);
                continue;
            }else{
                l = r;
            }
        }
        for(int l=0,r=1; r<n; r++){
            if(nums[r]-nums[r-1]<0){//递减
                ans = Math.max(ans, r-l+1);
                continue;
            }else{
                l = r;
            }
        }
        return ans;
    }
}

还有一种一次循环遍历就能解决的算法,就是分组循环算法,可以发现上述的两个循环其实只是 if 语句中的判断条件不同,其他没变,而这个 if 语句中判断条件就是来判断当前子数组是递增/递减的,所以当只使用一个循环的时候,就需要多一个变量来判断当前的子数组是递增/递减的,代码如下:

class Solution {
    public int longestMonotonicSubarray(int[] nums) {
        int n = nums.length;
        int i = 1;
        int ans = 1;
        while(i < n){
            if(nums[i] == nums[i-1]){//严格递增/递减
                i++;
                continue;
            }

            int i0 = i-1;//记录左端点
            boolean flg = nums[i] > nums[i-1];//判断以i0为左端点的子数组是递增/递减

            while(i<n && nums[i]!=nums[i-1] && flg == (nums[i] > nums[i-1])){
                //保证是递增或递减
                ans = Math.max(ans, i-i0+1);
                i++;
            }
        }
        return ans;
    }
}

二,3106. 满足距离约束且字典序最小的字符串

本题题意:给定一个字符串 s,可以任意修改其中的字符 k 次(对字符进行+1-1操作),返回一个字典序最小的字符串,(注:只有小写英文字母,z 和 a 首尾相连)

要返回一个字典序最小的字符串,就是优先将靠前的字符变成 a,如果不够就将当前字符变成ch - k,后面的字符不变。

这里需要注意的点是:这里的26个字母是一个类似于循环数组的东西,可以将该字符减小 ch-'a' 次变成a,也可以将该字符增加 'z' - ch + 1 次,使其先变成 z 再变成 a,所以要优先考虑操作次数小的方式。

代码如下:

class Solution {
    public String getSmallestString(String s, int k) {
        StringBuilder res = new StringBuilder();
        for(char ch : s.toCharArray()){
            int cnt1 = ch - 'a';//直接变成a
            int cnt2 = 'z' - ch + 1;//从z到a
            int mn = Math.min(cnt1, cnt2);
            if(k >= mn){//剩下的操作次数可以将ch变成'a'
                k -= mn;
                res.append('a');
            }else{//剩下的操作次数不能把ch变成'a'
                res.append((char)(ch-k));
                k = 0;
            }
        } 
        return res.toString();
    }
}

三,3107. 使数组中位数等于 K 的最少操作数

本题就是一道找中位数的题,可以先把数组排个序,当数组长度 n 为奇数时,中位数恰好是下标为 n/2 的数,而当数组长度为偶数时,因题目要求较大的数是中位数,这时的中位数恰好也是下标为 n/2 的数。

可以直接根据中位数和 k 的大小来分类讨论:

  • 如果 nums[n/2] > k,说明 n/2 之后的都数大于 k 不会影响中位数的产生,只需要往前遍历,如果 nums[i] > k,nums[i]要变成 k,需要操作nums[i]-k次,如果 nums[i] <= k,就说明 i 及之前的数都小于 k,不会影响中位数的产生,直接break
  • 如果nums[n/2] <= k,说明 n/2 之前的数都小于等于 k 不会影响中位数的产生,只需要往后遍历,如果 nums[i] > k,nums[i]要变成 k,需要操作k-nums[i]次,如果 nums[i] >= k,就说明 i 及之后的数都小于 k,不会影响中位数的产生,直接break
class Solution {
    public long minOperationsToMakeMedianK(int[] nums, int k) {
        Arrays.sort(nums);
        int n = nums.length;
        int m = n/2;
        long ans = 0;
        if(nums[m] > k){
            for(int i=m; i>=0; i--){//只要考虑前半部分
                if(nums[i]<k)
                    break;
                ans += nums[i] - k;
            }
        }else{
            for(int i=m; i<n; i++){//只要考虑后半部分
                if(nums[i]>k)
                    break;
                ans += k - nums[i];
            }
        }
        return ans;
    }
}

四,3108. 带权图里旅途的最小代价

本题要求 &的最小值,由&的性质可知,&的数越多,&的结果就越小,所以求 s -> t 的最小值,就是求 s,t 所在连通块的所有权值的 & 值。

一共分成三种情况:

  • s,t 不在同一个联通块中,即他们不相连,返回 -1
  • s,t 是同一个点,返回 0
  • s,t 在同一连通块中,返回该连通块所有边的权值的 &值

需要一个数组ids,ids[i] 表示 i 点属于 ids[i] 这个连通块,需要一个链表listAnd,listAnd.get(i) 表示第 i 个连通块的 and值,接下来就是计算了。

代码如下:

class Solution {
    List<Integer> listAnd = new ArrayList<>();//统计连通块的and值
    public int[] minimumCost(int n, int[][] edges, int[][] query) {
        //建图
        List<int[]>[] g = new ArrayList[n];
        Arrays.setAll(g, e->new ArrayList<>());
        for(int[] e : edges){
            int x = e[0], y = e[1], w = e[2];
            g[x].add(new int[]{y, w});
            g[y].add(new int[]{x, w});
        }

        int[] ids = new int[n];//统计每个点在哪个连通块中,同时用作记忆化
        Arrays.fill(ids, -1);//如果ids[i]>=0表示i已经访问过
        for(int i=0; i<n; i++){
            if(ids[i] < 0){
                //计算每个连通块的and值
                listAnd.add(dfs(i, g, ids));
            }
        }

        int[] ans = new int[query.length];
        for(int i=0; i<query.length; i++){
            int w = query[i][0];
            int v = query[i][1];
            if(w == v){
                ans[i] = 0;
            }else if(ids[w] != ids[v]){
                ans[i] = -1;
            }else{
                ans[i] = listAnd.get(ids[w]);
            }
        }
        return ans;
    }
    //计算每个联通块的and值
    int dfs(int x, List<int[]>[] g, int[] ids){
        int res = -1;
        ids[x] = listAnd.size();
        for(int[] y : g[x]){
            res &= y[1];
            if(ids[y[0]] < 0){
                res &= dfs(y[0], g, ids);
            }
        }
        return res;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/543567.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

深度学习图像处理基础工具——opencv 实战2 文档扫描OCR

输入一个文档&#xff0c;怎么进行文档扫描&#xff0c;输出扫描后的图片呢&#xff1f; 今天学习了 opencv实战项目 文档扫描OCR 问题重构&#xff1a;输入图像 是一个含有文档的图像——> 目标是将其转化为 规则的扫描图片 那么怎么实现呢&#xff1f; 问题分解&#…

量子城域网系列(三):搭建一个点对点量子保密通信网络

各位小伙伴周末愉快呀&#xff0c;今天是4月14日世界量子日&#xff0c;至于为今天是世界量子日可以围观我之前的文章&#xff1a;关于世界量子日。 之前的文章中我们讨论了量子密钥在通信系统各层协议中的应用&#xff0c;那在实际工程中如何真正落地一个量子加密网络呢&a…

【Linux】序列化与反序列化{服客编程/守护进程/JSON}

文章目录 1.引入2. 静态成员函数3.TCP&#xff1a;传输控制协议4.守护进程4.0前台进程4.1介绍4.2认识4.3会话4.3ps axj4.4理解4.5/dev/null4.6守护进程和孤儿进程 5.JSON6.完整代码6.1Makefile6.2Socket.hpp6.3Protocol.hpp6.4Log.hpp6.5Daemon.hpp6.6TcpServer.hpp6.7Client.c…

2024年DTC的回顾与思考

刚结束了2024的数据库技术嘉年华 这是我从2017年开始就参加的技术大会。中途因为疫情的耽误。正常来说我是连续的。知道我的朋友都知道我习惯炫耀一下。 按照惯例&#xff0c;此时此刻群友都在写大会回顾。只是有几个不讲武德的人已经发送了。下面有主观和客观的分析。 主观上…

HTML图片

图片标签&#xff1a; ~img图片标签 ~是自结束标签 ~属性 ~src表示要引入图片的位置 ~src需要一个路径作为参数 ~alt是对图片的描述 ~帮助搜索引擎来识别图片 ~如果不写alt则搜索引擎不会收录图片 ~width与height只有一个时是同步改变的&#xff0c;但两者同时存在时则是两者按…

AI来了,Spring还会远吗?(Spring AI初体验)

目录 一、创建项目二、first demo1、application.properties2、ChatController3、结果 三、个人思考 一、创建项目 官方文档的Getting Started 最低要求&#xff1a;JDK17 阿里云的Server URL&#xff08;https://start.aliyun.com/&#xff09;搜不到Spring AI&#xff0c;…

秒杀优化-Redis完成秒杀资格判断

6.2 秒杀优化-Redis完成秒杀资格判断 需求&#xff1a; 新增秒杀优惠券的同时&#xff0c;将优惠券信息保存到Redis中 基于Lua脚本&#xff0c;判断秒杀库存、一人一单&#xff0c;决定用户是否抢购成功 如果抢购成功&#xff0c;将优惠券id和用户id封装后存入阻塞队列 开启…

五月收到返稿意见,提示语言太差,需要润色

五月收到返稿意见&#xff0c;提示语言太差&#xff0c;需要润色&#xff0c;于是向周围伙伴们打听了是给润色公司还是别的润色软件润色比较好。得出的结论是&#xff0c;如果需要稳妥一点&#xff0c;还是找专门的润色机构&#xff0c;在返稿的时候&#xff0c;附上润色证明&a…

XTTS数据迁移

文章目录 一、全量迁移1、源端和目标端都需要配置XTTS脚本&#xff08;源库和目标库都需要进行下列配置&#xff09;2、源端调用 xttdriver.pl -p做迁移准备3、将源端的数据文件副本和rmanconvert.cmd传到目标端4、在目标端对数据文件拷贝进行字节序的转换 二、XTTS 第1~n次增量…

MES实施优势有哪些?MES制造执行系统的主要内容

各个行业之间也开始进入到了激烈的竞争当中&#xff0c;很多企业为了能够有效提升企业竞争力&#xff0c;都会通过提升自身实力的方式来提升竞争力。一些制造业也会在经营过程当中使用到MES系统&#xff0c;那么&#xff0c;mes系统的优势有哪些呢&#xff1f; 1、优化企业现场…

leetcode不同路径

. - 力扣&#xff08;LeetCode&#xff09; 62. 不同路径 中等 相关标签 相关企业 一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图中标记为 “Start” &#xff09;。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角&#xff08;在下…

欧姆龙61F系列液位开关使用教程(补水和排水)

欧姆龙61F系列液位开关使用教程(补水和排水) 本文以61F-LS-CP11-NRA型号的液位开关为例进行说明: 具体的选型文档可参考以下链接中的内容: OMRON欧姆龙-无浮标开关(紧凑插入型)61F-LS液位开关-选型样本说明 补水功能(供水) 如下图所示, 电机电源为3相AC220V; 控制电…

单例模式以及常见的两种实现模式

单例模式是校招中最常考的设计模式之一. 设计模式其实就是类似于“规章制度”&#xff0c;按照这个套路来进行操作。 单例模式能保证某个类在程序中只存在唯一 一份实例。而不会创建出多个实例&#xff0c;如果创建出了多个实例&#xff0c;就会编译报错。而不会创建出多个实…

MySQL优化慢SQL的6种方式

⛰️个人主页: 蒾酒 &#x1f525;系列专栏&#xff1a;《mysql经验总结》 &#x1f30a;山高路远&#xff0c;行路漫漫&#xff0c;终有归途 目录 写在前面 优化思路 优化方法 1.避免查询不必要的列 2.分页优化 3.索引优化 4.JOIN优化 5.排序优化 6.UNION 优化…

今天掏心窝子!聊聊35岁了程序员何去何从?

今天的内容不聊技术&#xff0c;聊聊轻松的话题&#xff0c;脑子高速转了好几周&#xff0c;停下来思考一下人生…… 不对&#xff0c;关于35岁的问题好像也不轻松&#xff0c;些许有点沉重&#xff0c;反正不是技术&#xff0c;不用高速转动脑细胞了&#xff0c;哈哈。 兄弟…

牛客 NC36 在两个长度相等的排序数组中找到上中位数【中等 模拟 Java,Go,PHP】

题目 题目链接&#xff1a; https://www.nowcoder.com/practice/6fbe70f3a51d44fa9395cfc49694404f 思路 直接模拟2个数组有顺序放到一个数组中&#xff0c;然后返回中间的数参考答案java import java.util.Scanner;// 注意类名必须为 Main, 不要有任何 package xxx 信息 pu…

图文教程 | 2024Typora最新版免费激活使用教程(新旧版可用)

一、打开官网下载最新版Typora Typora 官网下载 安装&#xff1a; Typora中文官网&#xff1a;https://typoraio.cn/ Typora官网&#xff1a;https://typora.io/releases/all 官网长这个样子 下面这个不是官网&#xff01;&#xff01;&#xff01;&#xff01;注意&#x…

【ArcGIS 脚本工具】在ArcPro中实现mdb转gdb

ArcGIS Pro作为主力使用很久了&#xff0c;但是ArcMap也从来没有卸载过。 要问为什么&#xff0c;就是还需要ArcMap来读写mdb数据库&#xff0c;Pro是不支持读写mdb数据库的。 我之前尝试过不借助ArcMap把mdb转成gdb&#xff0c;奈何技术太菜搞不定。 直到我看到了公众号【G…

基于springboot实现洗衣店订单管理系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现洗衣店订单管理系统演示 摘要 随着信息互联网信息的飞速发展&#xff0c;无纸化作业变成了一种趋势&#xff0c;针对这个问题开发一个专门适应洗衣店业务新的交流形式的网站。本文介绍了洗衣店订单管理系统的开发全过程。通过分析企业对于洗衣店订单管理系统…

JD抓包 | 安卓app抓包

去年11月份左右搞过一次安卓抓包, 搞了很久试了很多方法, 才弄好. 时隔半年, 安卓抓包依然是令我头疼的问题 这次简单记录一下过程(细节太多我也说不清) JD的有效信息接口通常是以下这样的, 其他的接口并没有返回太多"有用"的信息 https://api.m.jd.com/client.act…