Leetcode - 周赛384

目录

一,3033. 修改矩阵

二,3035. 回文字符串的最大数量

三,3036. 匹配模式数组的子数组数目 II


一,3033. 修改矩阵

 这道题直接暴力求解,先算出每一列的最大值,再将所有为-1的区域替换成该列的最大值,代码如下:

class Solution {public int[][] modifiedMatrix(int[][] matrix) {int n = matrix.length;int m = matrix[0].length;int[] max = new int[m];for(int j=0; j<m; j++){for(int i=0; i<n; i++){//得到每列的最大值max[j] = Math.max(max[j],matrix[i][j]);}}for(int i=0; i<n; i++){for(int j=0; j<m; j++){if(matrix[i][j] == -1){//是-1就进行替换matrix[i][j] = max[j];}}}return matrix;}
}

二,3035. 回文字符串的最大数量

 这道题是问我们:怎样交换可以使words数组包含最大数量的回文串,注意只要输出回文串的最大数量。再仔细看题就会发现,这些数组中字符都是可以相互交换的,也就是说,我们可以先使用hash或者int[26](题目说了只包含小写字母)来统计一下words数组中包含哪些字符及其对应的数目,再自己构造出固定长度的回文字符串。

这时还有一个问题,就是如何保证我们构造的字符串的数目一定是最大的,这里我们就要使用贪心的思想了,我们可以先得到words数组中字符串的长度,并将其从小到大排序,再根据长度从小到大来构造回文字符串,这样就可以保证构造出的回文字符串的数目是最大的。

其实再进一步想一想,回文字符串的特点是什么?不就是对称吗,也就是说我们根本不需要知道各个字符的数量,只需要知道,有多少成对的字符(使用two代替),又有多少单个字符(使用one来代替)。

大体思路想好了,剩下的就是如何构造字符串(假设我们要构造长度为x的回文字符串):

 1)剩下的字符可以构造出字符串, 即 two - x/2 >= 0 && one - x%2 >= 0,同时ans++

2)剩下的字符不可以构造出字符串: 

  1. 缺少成对的字符, 这时直接返回,因为我们是从小到大来构造字符串的,如果这个构造的字符串缺少成对的字符,那么后面的也一定缺少,即 two - x/2 < 0
  2. 缺少单个字符,即 one - x%2 < 0, 这时候我们要看two是否还多余,如果多余,我们可以从two中拿出一个,同时ans++ (注意:当我们从two中拿出一个时,我们的one也要同时+1,相当于是将一个成对的字符拆成单个字符来使用),如果缺少,直接返回。

进阶:上述讨论的2.2这种情况真的存在吗?

  • 我们这样想一想,当答案就等于words.length的时候,two是最大的,one是最小的,而当one是最小的时候,他也能满足单个字符的需求,也就是说,我们不需要关心one,只需要关心two,即 two - x/2 >= 0 或者  two - x/2 < 0,当 >= 0 时, ans++;当 < 0 时,直接返回答案。

上代码:

class Solution {public int maxPalindromesAfterOperations(String[] words) {int[] m = new int[26];//统计各个字符出现的次数int[] t = new int[words.length];//统计words数组中字符串的长度for(int i=0; i<words.length; i++){t[i] = words[i].length(); for(char ch : words[i].toCharArray()){m[ch-'a']++;}}Arrays.sort(t);//从小到大排序int two = 0;//统计成对字符的数目for(int i=0; i<26; i++){two += m[i]/2;}int ans = 0;for(int x : t){//从小到大构造回文字符串if(two-x/2>=0){two -= x/2;ans++;}else{return ans;}}return ans;    }
}

三,3036. 匹配模式数组的子数组数目 II

   

 这周周赛的二四题是相同的,这里就一起讲了。

该题的关键点在于是否能将这道题转换成一个 "字符串匹配" 问题:

我们通过题目给的条件:

  •  nums[i] - nums[i-1] > 0,t[i-1] = 1 
  • nums[i] - nums[i-1] == 0, t[i-1] = 0
  • nums[i] - nums[i-1] < 0, t[i-1] = -1

可以得到一个 int[] t = new int[nums.length-1] 的数组,然后通过kmp算法求数组 t 中有多少和数组pattern相同的字数组。 

 代码如下:

class Solution {public int countMatchingSubarrays(int[] nums, int[] pattern) {int n = nums.length;int[] t = new int[n-1];for(int i=1; i<n; i++){if(nums[i]-nums[i-1]==0)t[i-1] = 0;else if(nums[i]-nums[i-1]>0)t[i-1] = 1;else t[i-1] = -1;}//求next数组int k = pattern.length;int[] next = new int[k];for(int i=1, j=0; i<k; i++){while(j>0&&pattern[i]!=pattern[j]){j = next[j-1];}if(pattern[i]==pattern[j])j++;next[i] = j;}//字符串匹配int ans = 0;for(int i=0, j=0; i<n-1; i++){while(j>0&&j<k&&t[i]!=pattern[j]){j = next[j-1];}if(t[i]==pattern[j])j++;if(j==k){j = next[j-1];ans++;}}return ans;}
}

除了KMP算法之外,还可以通过Z函数算法来求解,下面简单来讲一讲Z函数算法的思想:和KMP的思路差不多,只不过kmp中的 next 数组是用来求字符串中的最长前后缀,而Z函数中的 z 数组则是用来求字符串的最长前前缀,举一个例子:

    

 使用该方法麻烦的点是:需要手动的将 pattern 数组添加到 t 数组的前面,然后只需要统计 z[i] (i >= pattern.length)大于等于 pattern.length 的数目就行了。

class Solution {public int countMatchingSubarrays(int[] nums, int[] pattern) {int n = nums.length;int[] t = new int[n-1];for(int i=1; i<n; i++){if(nums[i]-nums[i-1]==0)t[i-1] = 0;else if(nums[i]-nums[i-1]>0)t[i-1] = 1;else t[i-1] = -1;}List<Integer> ls = new ArrayList<>();for(int x : pattern) ls.add(x);for(int x : t) ls.add(x);int ans = 0;int k = pattern.length;int[] z = new int[ls.size()];int l=0, r=0;for(int i=1; i<ls.size(); i++){if(i <= r)z[i] = Math.min(z[i-l], r-i+1);while(i+z[i]<ls.size() && ls.get(z[i]) == ls.get(i+z[i])){l = i;r = i + z[i];z[i]++;}if(i>=k && z[i]>=k) ans++;}return ans;}
}

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

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

相关文章

qt-C++笔记之打印所有发生的事件

qt-C笔记之打印所有发生的事件 code review! 文章目录 qt-C笔记之打印所有发生的事件1.ChatGPT问答使用 QApplication 的 notify 方法使用 QObject 的 event 方法 2.使用 QObject 的 event 方法3.使用 QApplication 的 notify 方法 1.ChatGPT问答 在Qt C中&#xff0c;若要打…

树莓派5 EEPROM引导加载程序恢复镜像

树莓派5不能正常启动&#xff0c;可以通过电源led灯的闪码来判断错误发生的大致情形。 LED警告闪码 如果树莓派由于某种原因无法启动&#xff0c;或者不得不关闭&#xff0c;在许多情况下&#xff0c;LED会闪烁特定的次数来指示发生了什么。LED会闪烁几次长闪烁&#xff0c;然…

今日早报 每日精选15条新闻简报 每天一分钟 知晓天下事 2月17日,星期六

每天一分钟&#xff0c;知晓天下事&#xff01; 2024年2月17日 星期六 农历正月初八 1、 中疾控&#xff1a;我国自主研发的猴痘mRNA疫苗即将进入临床试验。 2、 2024年度总票房破100亿元&#xff0c;其中春节档已突破70亿元。 3、 国产大飞机首次国外亮相&#xff0c;C919已抵…

自动化测试-RIDE编写自动化脚本

自动化脚本软件测试的必修内容&#xff0c;是自动化测试的核心&#xff0c;脚本的逻辑严谨性、可维护性非常重要&#xff0c;优秀的自动化脚本需要能兼顾用例的正确有效性和自动化测试的效率&#xff0c;本篇文章将介绍如何用RIDE写自动化脚本。我们将深入探讨RIDE的具体用法&a…

Python hash函数

在Python编程中&#xff0c;hash()函数是一个重要的内置函数&#xff0c;用于计算对象的哈希值。哈希值是一种由固定长度的字符串表示的数据摘要&#xff0c;通常用于在散列表中快速查找、比较对象或数据完整性验证等场景。本文将深入探讨Python中的hash()函数&#xff0c;包括…

The method toList() is undefined for the type Stream

The method toList() is undefined for the type Stream &#xff08;JDK16&#xff09; default List<T> toList() { return (List<T>) Collections.unmodifiableList(new ArrayList<>(Arrays.asList(this.toArray()))); }

HarmonyOS一杯冰美式的时间 -- 验证码框

一、前言 像是短密码、验证码都有可能需要一个输入框&#xff0c;像是如下&#xff1a; 恰好在写HarmonyOS的时候也需要写一个验证码输入框&#xff0c;但是在实现的时候碰了几次灰&#xff0c;觉得有必要分享下&#xff0c;故有了此篇文章。 如果您有任何疑问、对文章写的不…

Compose 自定义 - 约束 Constrains

一、概念 是当前节点宽高的上下界&#xff08;最大值和最小值&#xff09;。在 Layout 阶段&#xff0c;当父节点测量子节点的时候会把 Contraints 往下传递&#xff0c;好让子元素知道自己被允许的最大最小尺寸&#xff0c;当所有子元素被测量完成后开始决定自身尺寸时&#x…

STM32

Unix时间戳 BKP 读写备份寄存器 main.c #include "stm32f10x.h" // Device header #include "Delay.h" #include "OLED.h" #include "Key.h"uint8_t KeyNum;uint16_t ArrayWrite[] {0x1234,0x2134}; uint16_t Arr…

【深度学习】Pytorch 系列教程(三):PyTorch数据结构:2、张量的数学运算(1):向量运算(加减乘除、数乘、内积、外积、范数、广播机制)

文章目录 一、前言二、实验环境三、PyTorch数据结构0、分类1、Tensor&#xff08;张量&#xff09;1. 维度&#xff08;Dimensions&#xff09;2. 数据类型&#xff08;Data Types&#xff09;3. GPU加速&#xff08;GPU Acceleration&#xff09; 2、张量的数学运算1. 向量运算…

Linux下解压tar.xz文件的命令

tar -c: 建立压缩档案-x&#xff1a;解压-t&#xff1a;查看内容-r&#xff1a;向压缩归档文件末尾追加文件-u&#xff1a;更新原压缩包中的文件 ------------------------------------------ 这五个是独立的命令&#xff0c;压缩解压都要用到其中一个&#xff0c;可以和别的…

互联网加竞赛 基于计算机视觉的身份证识别系统

0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 基于机器视觉的身份证识别系统 该项目较为新颖&#xff0c;适合作为竞赛课题方向&#xff0c;学长非常推荐&#xff01; &#x1f9ff; 更多资料, 项目分享&#xff1a; https://gitee.com/dancheng-sen…