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';//直接变成aint cnt2 = 'z' - ch + 1;//从z到aint 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;}
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Steam平台游戏发行流程

Steam平台游戏发行流程 大家好我是艾西&#xff0c;一个做服务器租用的网络架构师也是游戏热爱者&#xff0c;经常在steam平台玩各种游戏享受快乐生活。去年幻兽帕鲁以及雾锁王国在年底横空出世&#xff0c;幻兽帕鲁更是在短短一星期取得了非常好的成绩&#xff0c;那么作为游戏…

Python工程师面试高频题:return 和 yield之间到底有啥区别?

在编程语言 Python 中&#xff0c;yield 和 return 是两个在函数中用于返回值的关键字&#xff0c;但它们在功能和使用场景上有着本质的区别。理解这两者的区别&#xff0c;对于编写更高效、更灵活的 Python 代码至关重要。 看图说话 首先我们来看下面这张图片&#xff0c;该…

【C++】STL学习之vector的使用

&#x1f525;博客主页&#xff1a; 小羊失眠啦. &#x1f3a5;系列专栏&#xff1a;《C语言》 《数据结构》 《C》 《Linux》 《Cpolar》 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 文章目录 前言一、默认成员函数1.1 默认构造1.2 拷贝构造1.3 析构函数1.4 赋值重载 二、迭…

系统架构最佳实践 -- 金融企业的资损防控

一、资损产生的原因 由于支付行业的特殊性与复杂性&#xff08;主要处理资金相关业务&#xff09;&#xff0c;支付公司处于资损的风口浪尖&#xff0c;最容易发生资损&#xff0c;可以说资损风险无处不在。 常规来说&#xff0c;资损原因主要可以分为以下三类&#xff1a; 1…

【数据结构】树与二叉树遍历算法的应用(求叶子节点个数、求树高、复制二叉树、创建二叉树、二叉树存放表达式、交换二叉树每个结点的左右孩子)

目录 求叶子节点个数、求树高、复制二叉树、创建二叉树、二叉树存放表达式、交换二叉树每个结点的左右孩子应用一&#xff1a;统计二叉树中叶子结点个数的算法写法一&#xff1a;使用静态变量写法二&#xff1a;传入 count 作为参数写法三&#xff1a;不使用额外变量 应用二&am…

Mybatis中SqlSession接口中的selectList方法

1、SqlSession SqlSession是Mybatis持久层框架提供的接口&#xff0c;该接口中包含了大量的CRUD操作方法&#xff08;既增删改查方法&#xff09;。 2、selectList方法 selectList方法是用于查询的方法&#xff0c;该方法具有多态性&#xff0c;如图所示&#xff08;打开myb…

使用cmake进行打包,包含可执行程序和动态依赖库

平常代码开发中&#xff0c;有时候需要将写的程序打包成压缩包放到目标设备上进行运行测试。用CMake管理工程&#xff0c;实现使用make -jnproc package指令可以将工程进行打包&#xff0c;可执行文件存储在bin文件夹中&#xff0c;依赖库存储在lib文件夹中。 示例 1.工程目录结…

靠谱的大型相亲交友婚恋平台有哪些?相亲app软件前十名

靠谱交友软件&#xff0c;个人感觉还是要选择大型的&#xff0c;口碑好的进行选择&#xff0c;以下是我用过的婚恋平台&#xff0c;分享给大家 1、丛丛 这是我用的最久的一款脱单小程序&#xff0c;我老公就是在这个小程序找到的&#xff01;&#xff01;&#xff01; 这是一款…

CF938Div3(A-F)

A: 买n个酸奶&#xff0c;一次一瓶a元,一次买两瓶可以优惠价b元,也可以a元,问恰好买n瓶需要多少钱. void solve() {int n, a, b;cin >> n >> a >> b;int ans min(a * n, n / 2 * b n % 2 * a);cout << ans << endl; } B: 给你一个数组,问能…

2024最新在线工具箱网站系统源码

2024最新在线工具箱网站系统源码 下载地址: 2024最新在线工具箱网站系统源码-JXASP源码网https://www.jxasp.com/think-php/12489.html

Python零基础入门到精通学习教程2024年最新版,看完这一篇就够了。

前言 2023年即将接近尾声&#xff0c;随着2024年的到来&#xff0c;Python即将步入他的35岁诞生。&#xff08;冷知识&#xff1a;Python1989年诞生&#xff0c;Java是1991年&#xff0c;所以Python比Java更加历史悠久&#xff09;作为当今世界上最受欢迎的编程语言。不少小伙…

Base64编码方式简介

从二进制转为字符的一种编码。每个base64字符表示长度为6个比特的二进制数据&#xff0c;因此可以推得每3个字节&#xff08;24比特&#xff09;可以由4个base64字符组成。base64字符编码表如下&#xff1a; 因此需要注意的是&#xff0c;当二进制文件长度不是3的倍数的时候&a…