【周赛复盘】LeetCode第296场单周赛 悠悠 2023-10-01 22:04 38阅读 0赞 #### 目录 #### * 1、极大极小游戏 * * 1)题目描述 * 2)原题链接 * 3)思路解析 * 4)模板代码 * 5)算法与时间复杂度 * 2、划分数组使最大差为 K * * 1)题目描述 * 2)原题链接 * 3)思路解析 * 4)模板代码 * 5)算法与时间复杂度 * 3、替换数组中的元素 * * 1)题目描述 * 2)原题链接 * 3)思路解析 * 4)模板代码 * 5)算法与时间复杂度 * 4、设计一个文本编辑器 * * 1)题目描述 * 2)原题链接 * 3)思路解析 * 4)模板代码 * 5)算法与时间复杂度 * 5、周赛总结 ## 1、极大极小游戏 ## ### 1)题目描述 ### > 给你一个下标从 **0** 开始的整数数组 `nums` ,其长度是 `2`的幂。 > 对 nums 执行下述算法: > 设 `n` 等于 `nums` 的长度,如果 `n == 1` ,**终止**算法过程。否则,创建 一个新的整数数组 `newNums` ,新数组长度为 `n / 2` ,下标从 **0** 开始。 > 对于满足 `0 <= i < n / 2` 的每个 **偶数** 下标 `i`,将 `newNums[i]` 赋值 为 `min(nums[2 * i], nums[2 * i + 1])` 。 > 对于满足 `0 <= i < n / 2` 的每个 **奇数** 下标 `i` ,将 **newNums\[i\]** 赋值 为 `max(nums[2 * i], nums[2 * i + 1])` 。 > 用 `newNums` 替换 `nums` 。 > 从步骤 1 开始 **重复** 整个过程。 > 执行算法后,**返回 nums 中剩下的那个数字。** > ![在这里插入图片描述][b85d6931351d47069643aa796e3d9d7d.png] ### 2)原题链接 ### > 原题链接:[LeetCode.6090:极大极小游戏][LeetCode.6090] ### 3)思路解析 ### * ( 1 ) (1) (1)题意比较清楚,直接模拟即可。 * ( 2 ) (2) (2)使用数组或者队列模拟都行,这里我使用递归,出口则当长度`n`为1的时候。 ### 4)模板代码 ### class Solution { public int minMaxGame(int[] arr) { int[] s=test(arr); return s[0]; } int[] test(int[] arr){ int n=arr.length; if (n==1) return arr; int[] s=new int[n/2]; for (int i = 0; i <n/2; i++) { if (i%2==0){ s[i]=Math.min(arr[i*2],arr[i*2+1]); }else{ s[i]=Math.max(arr[i*2],arr[i*2+1]); } } return test(s); } } ### 5)算法与时间复杂度 ### 算法:**模拟** 时间复杂度:每次递归数组长度减半,总共递归 l o g n logn logn次,时间复杂度为 O ( l o g n ) O(logn) O(logn)。 ## 2、划分数组使最大差为 K ## ### 1)题目描述 ### > 给你一个整数数组 `nums` 和一个整数 `k` 。你可以将 `nums`划分成一个或多个 **子序列** ,使 nums 中的每个元素都 **恰好** 出现在一个子序列中。 > 在满足每个子序列中最大值和最小值之间的差值最多为 `k` 的前提下,返回需要划分的 **最少** 子序列数目。 > **子序列** 本质是一个序列,可以通过删除另一个序列中的某些元素(或者不删除)但不改变剩下元素的顺序得到。 ### 2)原题链接 ### > 原题链接:[LeetCode.6091:划分数组使最大差为 K][LeetCode.6091_ K] ### 3)思路解析 ### * ( 1 ) (1) (1)由于是子序列而不是子数组,加上需要考虑子序列内的最大值和最小值,我们可以考虑先将数组排序。 * ( 2 ) (2) (2)用指针`pre`指向当前最小的数,在它的右边找到最大的满足减去自身的差不超过`k`的数`nxet`, \[ p r e , n e x t \] \[pre,next\] \[pre,next\]这就可以当做一段子序列。 * ( 3 ) (3) (3)更新`pre`为`next+1`,直到整个数组遍历完。由于数组已经排好序,对于第二步我们可以考虑使用**二分查找**来搜索`next`。 * ( 4 ) (4) (4)第二步也可以直接遍历数组查找,时间复杂度为 O ( n ) O(n) O(n),没什么太大影响。 ### 4)模板代码 ### class Solution { public int partitionArray(int[] arr, int k) { Arrays.sort(arr); int n=arr.length; int pre=0; int c=0; while (pre<n){ int l=pre; int r=n-1; while (l<r){ int mid=(l+r+1)>>1; if (arr[mid]-arr[pre]<=k) l=mid; else r=mid-1; } pre=r+1; c++; } return c; } } ### 5)算法与时间复杂度 ### 算法:**贪心、排序** 时间复杂度:排序的时间复杂度为 O ( n l o g n ) O(nlogn) O(nlogn),每次二分的时间复杂度为 O ( l o g n ) O(logn) O(logn),整体时间复杂度为 O ( n ) O(n) O(n)。 ## 3、替换数组中的元素 ## ### 1)题目描述 ### > 给你一个下标从 `0` 开始的数组 `nums` ,它包含 n 个 **互不相同** 的正整数。请你对这个数组执行 `m` 个操作,在第 `i` 个操作中,你需要将数字 `operations[i][0]` 替换成 `operations[i][1]` 。 > 题目保证在第 i 个操作中: > `operations[i][0]` 在 `nums` 中存在。 > `operations[i][1]` 在 `nums` 中不存在。 > 请你返回执行完所有操作后的数组。 ### 2)原题链接 ### > 原题链接:[LeetCode.6092:替换数组中的元素][LeetCode.6092] ### 3)思路解析 ### * ( 1 ) (1) (1)每次需要用`x`去替换`y`,所以我们得知道`y`在原数组中的位置,这一步可以用哈希表存储。`arr[i]`为key,`i`为值。 * ( 2 ) (2) (2)一个位置的数有可能被多次替换,所以每次替换完以后我们需要把数再次存入哈希表中。 ### 4)模板代码 ### class Solution { Map<Integer,Integer> map=new HashMap<>(); public int[] arrayChange(int[] arr, int[][] s) { int n=arr.length; for (int i = 0; i < n; i++) { map.put(arr[i],i); } for (int[] c:s){ int a=c[0]; int b=c[1]; int index=map.get(a); arr[index]=b; map.put(b,index); } return arr; } } ### 5)算法与时间复杂度 ### 算法:**模拟、哈希表** 时间复杂度:使用哈希表进行纯模拟操作,时间复杂度为 O ( n ) O(n) O(n)。 ## 4、设计一个文本编辑器 ## ### 1)题目描述 ### > 请你设计一个带光标的文本编辑器,它可以实现以下功能: > **添加**:在光标所在处添加文本。 > **删除**:在光标所在处删除文本(模拟键盘的删除键)。 > **移动**:将光标往左或者往右移动。 > 当删除文本时,只有光标左边的字符会被删除。光标会留在文本内,也就是说任意时候 `0 <= cursor.position <= currentText.length` 都成立。 > 请你实现 `TextEditor` 类: > `TextEditor()` 用空文本初始化对象。 > `void addText(string text)` 将 text 添加到光标所在位置。添加完后光标在 text 的右边。 > `int deleteText(int k)` 删除光标左边 `k` 个字符。返回实际删除的字符数目。 > `string cursorLeft(int k)` 将光标向左移动 `k` 次。返回移动后光标左边 `min(10, len)` 个字符,其中 `len` 是光标左边的字符数目。 > `string cursorRight(int k)` 将光标向右移动 `k` 次。返回移动后光标左边 `min(10, len)` 个字符,其中 `len` 是光标左边的字符数目。 ### 2)原题链接 ### > 原题链接:[LeetCode.6093:设计一个文本编辑器 > ][LeetCode.6093_] ### 3)思路解析 ### * ( 1 ) (1) (1)`Java`语言使用`StringBuilder`进行模拟,使用一个变量`index`模拟光标。`indx`指向待删除的元素,初始值我们赋值为`-1`。表示字符串为空。 * ( 2 ) (2) (2)每一步根据题意进行模拟即可,注意对边界的把握。 * ### 4)模板代码 ### class TextEditor { StringBuilder sb; int idx; public TextEditor() { sb=new StringBuilder(); idx=-1; } public void addText(String text) { sb.insert(idx+1,text); idx+=text.length(); } public int deleteText(int k) { //全部删完 if (idx+1<=k){ sb.delete(0,idx+1); //System.out.println(sb); int g=idx; idx=-1; return g+1; }else{ //删除部分 sb.delete(idx+1-k,idx+1); //System.out.println(sb); idx-=k; return k; } } public String cursorLeft(int k) { idx=Math.max(-1,idx-k); if (idx==-1) return ""; //长度大于等于10的情况 if (idx>=9) return sb.substring(idx+1-10,idx+1); return sb.substring(0,idx+1); } public String cursorRight(int k) { idx=Math.min(idx+k,sb.length()-1); if (idx==-1) return ""; //长度大于等于10的情况 if (idx>=9) return sb.substring(idx+1-10,idx+1); return sb.substring(0,idx+1); } } ### 5)算法与时间复杂度 ### 算法:**模拟** 时间复杂度:大模拟题没有分析意义。 ## 5、周赛总结 ## 整体难度较低,但`wa`了五次,应当反思,多注意细节情况。做之前明确好题意再下手。 [b85d6931351d47069643aa796e3d9d7d.png]: https://img-blog.csdnimg.cn/b85d6931351d47069643aa796e3d9d7d.png [LeetCode.6090]: https://leetcode.cn/problems/min-max-game/ [LeetCode.6091_ K]: https://leetcode.cn/problems/partition-array-such-that-maximum-difference-is-k/ [LeetCode.6092]: https://leetcode.cn/problems/replace-elements-in-an-array/ [LeetCode.6093_]: https://leetcode.cn/problems/design-a-text-editor/
相关 【周赛复盘】LeetCode第80场双周赛 目录 1、强密码检验器 II 1)题目描述 2)原题链接 3)思路解析 4)模板代码 5)算法与 太过爱你忘了你带给我的痛/ 2023年10月01日 22:07/ 0 赞/ 33 阅读
相关 【周赛复盘】LeetCode第296场单周赛 目录 1、极大极小游戏 1)题目描述 2)原题链接 3)思路解析 4)模板代码 5)算法与时间复 悠悠/ 2023年10月01日 22:04/ 0 赞/ 39 阅读
相关 【周赛复盘】力扣第 312 场单周赛 1.按身高排序 1)题目描述 给你一个字符串数组 `names` ,和一个由 互不相同 的正整数组成的数组 `heights` 。两个数组的长度均为 `n` 。 偏执的太偏执、/ 2023年09月28日 23:11/ 0 赞/ 27 阅读
相关 【周赛复盘】力扣第 86 场双周赛 目录 1. 和相等的子数组 1)题目描述 2)原题链接 3)思路解析 4)模板代码 5)算法与时 柔情只为你懂/ 2023年09月28日 23:01/ 0 赞/ 13 阅读
相关 【周赛复盘】力扣第 85 场双周赛 目录 1. 得到 K 个黑块的最少涂色次数 1)题目描述 2)原题链接 3)思路解析 4)模板代码 ╰+哭是因爲堅強的太久メ/ 2023年09月28日 21:26/ 0 赞/ 55 阅读
相关 【周赛复盘】力扣第 305 场单周赛 目录 1.算术三元组的数目 1)题目描述 2)原题链接 3)思路解析 4)模板代码 5)算法与时 忘是亡心i/ 2023年09月28日 18:58/ 0 赞/ 25 阅读
相关 【周赛复盘】LeetCode第304场单周赛 目录 1.使数组中所有元素都等于零 1)题目描述 2)原题链接 3)思路解析 4)模板代码 5) ゝ一世哀愁。/ 2023年09月28日 17:44/ 0 赞/ 52 阅读
相关 【周赛复盘】LeetCode第81场双周赛 目录 1、统计星号 1)题目描述 2)原题链接 3)思路解析 4)模板代码 5)算法与时间复杂度 悠悠/ 2023年09月28日 12:12/ 0 赞/ 43 阅读
相关 【周赛复盘】LeetCode第298场单周赛 目录 1、兼具大小写的最好英文字母 1)题目描述 2)原题链接 3)思路解析 4)模板代码 5) 一时失言乱红尘/ 2023年09月28日 11:10/ 0 赞/ 155 阅读
还没有评论,来说两句吧...