leetcode conttest 303
周赛这个难度,真心是质量下降太多了。
6124. 第一个出现两次的字母
题目
给你一个由小写英文字母组成的字符串 s ,请你找出并返回第一个出现 两次 的字母。
注意:
- 如果
a的 第二次 出现比b的 第二次 出现在字符串中的位置更靠前,则认为字母a在字母b之前出现两次。 s包含至少一个出现两次的字母。
示例 1:
输入:s = "abccbaacz" |
示例 2:
输入:s = "abcdd" |
提示:
2 <= s.length <= 100s由小写英文字母组成s包含至少一个重复字母
地址
https://leetcode.cn/contest/biweekly-contest-83/problems/best-poker-hand/
题意
直接遍历
思路
- 简单题目,直接尝试所有的可能即可
- 复杂度分析:
- 时间复杂度:$O(n)$,其中 $n$ 为字符串的长度。
- 空间复杂度:$O(\Sigma)$。
代码
class Solution { |
6125. 相等行列对
题目
给你一个下标从 0 开始、大小为 n x n 的整数矩阵 grid ,返回满足 Ri 行和 Cj 列相等的行列对 (Ri, Cj) 的数目。
如果行和列以相同的顺序包含相同的元素(即相等的数组),则认为二者是相等的。
示例 1:
输入:grid = [[3,2,1],[1,7,6],[2,7,7]] |
示例 2:
输入:grid = [[3,1,2,2],[1,4,4,5],[2,4,2,2],[2,4,2,2]] |
提示:
n == grid.length == grid[i].length1 <= n <= 2001 <= grid[i][j] <= 105
地址
https://leetcode.cn/contest/weekly-contest-303/problems/equal-row-and-column-pairs/
题意
直接遍历
思路
- 题目可以算是简单题目,直接遍历矩阵的每个元素 $(x,y)$,然后比较第 $x$ 行的元素与第 $j$ 列的元素是否相等。
- 复杂度分析:
- 时间复杂度:时间复杂度为 $O(n^3)$,$n$ 表示矩阵的行数。
- 空间复杂度:$O(1)$。
代码
class Solution { |
6126. 设计食物评分系统
题目
设计一个支持下述操作的食物评分系统:
修改 系统中列出的某种食物的评分。
返回系统中某一类烹饪方式下评分最高的食物。
实现 FoodRatings 类:
FoodRatings(String[] foods, String[] cuisines, int[] ratings)初始化系统。食物由foods、cuisines和。ratings描述,长度均为n。foods[i]是第i种食物的名字。cuisines[i]是第i种食物的烹饪方式。ratings[i]是第i种食物的最初评分。void changeRating(String food, int newRating)修改名字为food的食物的评分。String highestRated(String cuisine)返回指定烹饪方式cuisine下评分最高的食物的名字。如果存在并列,返回 字典序较小 的名字。
注意,字符串x的字典序比字符串y更小的前提是:x在字典中出现的位置在y之前,也就是说,要么x是y的前缀,或者在满足x[i] != y[i]的第一个位置i处,x[i]在字母表中出现的位置在y[i]之前。
示例:
输入 |
提示:
1 <= n <= 2 * 104n == foods.length == cuisines.length == ratings.length1 <= foods[i].length, cuisines[i].length <= 10foods[i]、cuisines[i]由小写英文字母组成1 <= ratings[i] <= 108foods中的所有字符串 互不相同- 在对
changeRating的所有调用中,food是系统中食物的名字。 - 在对
highestRated的所有调用中,cuisine是系统中 至少一种 食物的烹饪方式。 - 最多调用
changeRating和highestRated总计2 * 104次
地址
https://leetcode.cn/contest/biweekly-contest-83/problems/design-a-number-container-system/
题意
hash
思路
- 简单的
hash,设两个hash。arr中存放着食物名称对应的烹饪方式和评分,cnt存储着食物烹饪方式对应着的食物和评分的排名。 - 复杂度分析:
- 时间复杂度:时间复杂度为 $O(n)$。
- 空间复杂度:空间复杂度为 $O(n)$。
代码
struct cmp { |
6127. 优质数对的数目
题目
给你一个下标从 0 开始的正整数数组 nums 和一个正整数 k 。
如果满足下述条件,则数对 (num1, num2) 是 优质数对 :
num1和num2都 在数组nums中存在。num1 OR num2和num1 AND num2的二进制表示中值为1的位数之和大于等于k,其中OR是按位 或 操作,而AND是按位 与 操作。
返回 不同 优质数对的数目。
如果 a != c 或者 b != d ,则认为 (a, b) 和 (c, d) 是不同的两个数对。例如,(1, 2) 和 (2, 1) 不同。
注意:如果 num1 在数组中至少出现 一次 ,则满足 num1 == num2 的数对 (num1, num2) 也可以是优质数对。
示例 1:
输入:nums = [1,2,3,1], k = 3 |
示例 2:
输入:nums = [5,1,1], k = 10 |
提示:
1 <= nums.length <= 1051 <= nums[i] <= 1091 <= k <= 60
地址
https://leetcode.cn/contest/weekly-contest-303/problems/number-of-excellent-pairs/
题意
数学问题
思路
- 我们设 $bits(x)$ 表示 $x$ 的二进制位中含有 $1$ 的为数,此时我们数学推理可以知道 $bits(x|y) + bits(x \And y) = bits(x) + bits(y)$,知道以上推理后,则这个题目就转换成了求数组中的两个数之和大于等于给定值的不同数对有多少个,题目就变的非常简单了。
- 首先我们为了去重,首先把数组中的重复元素全部去掉,因为重复的元素对应的数对相同,然后将其中的元素 $x$ 全部转化为 $bits(x)$,然后再转化的数组中找到满足两个元素之和大于等于 $k$ 的数对有多少个。
- 复杂度分析:
- 时间复杂度:$O(n \log n)$,$n$ 表示数组的长度。
- 空间复杂度:$O(n)$,$n$ 表示数组的长度。
代码
class Solution { |
欢迎关注和打赏,感谢支持!
- 关注我的博客: http://mikemeng.org/
- 关注我的知乎:https://www.zhihu.com/people/da-hua-niu
- 关注我的微信公众号: 公务程序猿

扫描二维码,分享此文章