【LeetCode第 313 场周赛】忘光光
比赛链接
最近不怎么打比赛,不能马上反应过来考察的是什么,全部忘光光了...
6192. 公因子的数目
题意:
给定 \(a\) 和 \(b\),问两者的公因子数量
数据范围:\(1\leq a,b\leq 1000\)
题解:
从 \(1\) 到 \(\min(a,b)\) 暴力枚举判断即可
答案为:\(\sum\limits_{i=1}^{min(a,b)} [a\%i==0\ and\ b\%i==0]\)
时间复杂度:\(O(min(a,b))\)
代码:
class Solution {
public:
int commonFactors(int a, int b) {
int ans = 0;
for (int i = min(a, b); i >= 1; --i)
if (a % i == 0 && b % i == 0) ans += 1;
return ans;
}
};
6193. 沙漏的最大总和
题意:
给定一个 \(n\times m\) 的矩阵 \(grid\),问其中所有的满足如下形状的元素之和最大是多少
数据范围:\(3\leq n, m\leq 150, 0\leq grid[i][j]\leq 10^6\)

题解:
如图所示,就是求任意一个形状如上图所示的,A+B+C+D+E+F+G的和最大是多少,
那么暴力模拟即可,可以枚举左上角,注意左上角必须保证 \(i+2<n\ and\ j+2<m\)
时间复杂度:\(O(n\times m)\)
代码:
class Solution {
public:
int maxSum(vector<vector<int>>& g) {
int ans = 0;
int n = g.size(), m = g[0].size();
for (int i = 0; i + 2 < n; ++i)
for (int j = 0; j + 2 < m; ++j) {
int sum = 0;
for (int a = 0; a < 3; ++a)
for (int b = 0; b < 3; ++b)
sum += g[i + a][j + b];
sum = (sum - g[i + 1][j] - g[i + 1][j + 2]);
ans = max(ans, sum);
}
return ans;
}
};
6194. 最小 XOR
题意:
给定两个数 \(num1\) 和 \(num2\),请你求出一个数 \(x\) ,满足 \(x\) 和 \(num2\) 在二进制位上的 \(1\) 数量相同,同时使得 x XOR num1 尽可能小。
数据范围:\(1\leq num1, num2\leq 10^9\)
题解:
这里令 \(cnt(a)\) 为 \(a\) 的二进制中 \(1\) 的数量
分类讨论:
- 当 \(cnt(num1) == cnt(num2)\),此时 \(x = num1\) 即为答案
- 当 \(cnt(num1) > cnt(num2)\),此时 \(x\) 和 \(num1\) 异或后使得答案尽可能小,即优先抹去 \(num1\) 的高位二进制 \(1\)。
- 当 \(cnt(num1) < cnt(num2)\),此时可以将 \(num1\) 中的所有二进制位 \(1\) 全部抹去,此外再从小到大将 \(num1\) 中二进制位为 \(0\) 的对应的位置置为 \(1\),这样使得答案尽可能小,这里只需要添加 \(cnt(num2)-cnt(num1)\) 个 \(1\)
时间复杂度:\(O(bit)\),其中 \(bit\) 为 \(int\) 范围内的数二进制位的个数
代码:
class Solution {
public:
int minimizeXor(int num1, int num2) {
int c1 = 0, c2 = 0;
for (int i = 0; i < 30; ++i) {
if (num1 >> i & 1) c1 += 1;
if (num2 >> i & 1) c2 += 1;
}
if (c1 == c2) return num1;
if (c1 > c2) {
int sum = 0;
for (int i = 29; i >= 0 && c2 > 0; --i)
if (num1 >> i & 1) {
c2 -= 1;
sum |= 1 << i;
}
return sum;
} else {
int sum = 0;
c2 -= c1;
for (int i = 0; i < 30 && c2 > 0; ++i)
if (!(num1 >> i & 1)) {
c2 -= 1;
sum |= 1 << i;
}
return sum + num1;
}
}
};
6195. 对字母串可执行的最大删除数
题意:
给定一个长度为 \(n\) 的字符串 \(s\),每次有两种删除操作:
- 删除当前整个串 \(s\)
- 当存在一个 \(i\) 使得 \(s[0:i]==s[i:2\times i]\),那么可以删除 \(s[0:i]\)
问最多可以进行多少次删除操作?
数据范围:\(1\leq n\leq 4000, s[i]\) 均为小写字母
题解:
考虑 \(dp\), \(f[i]\) 为删除 \(s[i:n]\) 的最多次数。
状态转移方程:
- 直接删除整个串:\(f[i]=1\)
- 当 \(s[i:i+j]==s[i+j:i+2\times j]: f[i] = \max\limits_{j=1}^{len}\{f[j]+1\}\)
时间复杂度:\(O(n^2)\),其中由字符串哈希来 \(O(1)\) 判断字符串是否相同
代码:
typedef unsigned long long ull;
const ull P = 13331;
class Solution {
public:
int deleteString(string s) {
int n = s.size();
s = " " + s;
vector<ull> h(n + 1, 0);
vector<ull> p(n + 1, 1);
for (int i = 1; i <= n; ++i) {
h[i] = h[i - 1] * P + s[i];
p[i] = p[i - 1] * P;
}
vector<int> f(n + 1, 0);
function<int(int)> get = [&](int id) {
if (f[id]) return f[id];
f[id] = 1;
for (int len = 1; id + len * 2 - 1 <= n; ++len) {
ull a = (h[id + len - 1] - p[len] * h[id - 1]);
ull b = (h[id + len * 2 - 1] - p[len] * h[id + len - 1]);
if ((h[id + len - 1] - p[len] * h[id - 1]) == (h[id + len * 2 - 1] - p[len] * h[id + len - 1]))
f[id] = max(f[id], get(id + len) + 1);
}
return f[id];
};
return get(1);
}
};
【LeetCode第 313 场周赛】忘光光的更多相关文章
- LeetCode 第 165 场周赛
LeetCode 第 165 场周赛 5275. 找出井字棋的获胜者 5276. 不浪费原料的汉堡制作方案 5277. 统计全为 1 的正方形子矩阵 5278. 分割回文串 III C 暴力做的,只能 ...
- Leetcode第 217 场周赛(思维量比较大)
Leetcode第 217 场周赛 比赛链接:点这里 做完前两题我就知道今天的竞赛我已经结束了 这场比赛思维量还是比较大的. 1673. 找出最具竞争力的子序列 题目 给你一个整数数组 nums 和一 ...
- Leetcode 第133场周赛解题报告
今天参加了leetcode的周赛,算法比赛,要求速度比较快.有思路就立马启动,不会纠结是否有更好的方法或代码可读性.只要在算法复杂度数量级内,基本上是怎么实现快速就怎么来了. 比赛时先看的第二题,一看 ...
- LeetCode第151场周赛(Java)
这是我第一次写周赛的题目,而且还是虚拟的.从这次起,以后就将所有错过的题目都写到博客来.当然既然是我错的,那代码肯定不是我自己的.我会注明来源.并且我会自己敲一遍.多总结总是没坏处的. 另外比较糟糕的 ...
- LeetCode第152场周赛(Java)
这算是我第一次正式参加 LeetCode 的周赛吧.通过两道题.意料之中(通过上次模拟可以看出来).总的来说,脑袋还是不太灵光.想的有点慢.全球第一名 0:10:19 就全部通过...感觉我的智商被狠 ...
- Leetcode 第137场周赛解题报告
今天的比赛的题目相对来说比较「直白」,不像前几周都是一些特定的算法,如果你没学过不可能想出来. 做了这些周,对leetcode比赛的题目也发现了一些「规律」. 一般前两道题都很「简单」,只要有想法,直 ...
- LeetCode 第 150 场周赛
一.拼写单词(LeetCode-1160) 1.1 题目描述 1.2 解题思路 由于给定的chars,每个字母只能用一次,所以用大小为26的数组charsArray来表示a-z(例如charsArra ...
- LeetCode 第 196 场周赛 (题目:5452-5455,这是参加过最坑的周赛,暴力n^2居然可以过)
5452. 判断能否形成等差数列 给你一个数字数组 arr . 如果一个数列中,任意相邻两项的差总等于同一个常数,那么这个数列就称为 等差数列 . 如果可以重新排列数组形成等差数列,请返回 tru ...
- Leetcode 第136场周赛解题报告
周日的比赛的时候正在外面办事,没有参加.赛后看了下题目,几道题除了表面要考的内容,还是有些能发散扩展的地方. 做题目不是最终目的,通过做题发现知识盲区,去研究学习,才能不断提高. 理论和实际是有关系的 ...
随机推荐
- P3622 [APIO2007]【一本通提高状态压缩类动态规划】动物园
广告 绿树公司 - 官方网站:https://wangping-lvshu.github.io/LvshuNew/ 绿树智能 - 官方网站:https://wangping-lvshu.github. ...
- NoSQL,关系型数据库,行列数据库对比、类比
数据库对比.类比 关系型数据库.NoSQL 关系型数据库 表与表之间有关系.表存储一些格式化的数据结构,每个元组字段的组成都一样,这样便于表之间的联结操作.不过也限制了其性能瓶颈. 更支持SQL,支持 ...
- zabbix监控添加学习笔记
在实际生产环境中,除了CPU.内存等一些系统信息可以挂载zabbix的自带模板Template OS Linux:但是一些公司开发的定制服务需要自己写模板或者监控项去监控: 一.监控公司的java服务 ...
- .NET性能优化-使用SourceGenerator-Logger记录日志
前言 在现在许许多多的应用系统中,日志非常关键,它即是排查问题的强力工具,也是程序员居家旅行工作甩锅必备良品. 在团队中编码中,我们都要求对于那些会变更数据的接口.调用第三方的接口记录请求和响应参数, ...
- day13--Java常用类
Java常用类 1.包装类 1.1什么是包装类? Java 是面向对象的语言,但不是"纯面向对象"的,比如我们经常用到的基本数据类型就不是对象. 在我们实际应用中,经常需要将基本数 ...
- MES对接Simba实现展讯平台 IMEI 写号与耦合测试
文章开始之前,必须对Simba工具点一个大大的赞,Simba为了适应市面上不同厂家开发的 MES 系统,特地开发了统一的接口,各个 MES 厂家只需要按照接口规范去做开发,然后将中间件加载到 Simb ...
- 大数据管理系统架构Hadoop
Hadoop 起源于Google Lab开发的Google File System (GFS)存储系统和MapReduce数据处理框架.2008年,Hadoop成了Apache上的顶级项目,发展到今天 ...
- 从贡献第一个 pr 开始,我的开源之路正式开启
点击上方蓝字关注我们 1 我是一名开源爱好者 我是李进勇,Github Id:JinyLeeChina,目前就职于政采云,专注于大数据平台及数仓领域,是开源项目爱好者. 2 我与小海豚的不解之缘 记得 ...
- java-运算符以及简单运用
运算符: 1)赋值运算符:= 2)算术运算符:+-*/%,++,-- 3)关系运算符:>,<,>=,<=,==,!= boolean 4)逻辑运算符:&&,|| ...
- k8s中ingress,service,depoyment,pod如何关联
k8s中pod通过label标签名称来识别关联,它们的label name一定是一样的.ingress,service,depoyment通过selector 中app:name来关联 1.查询发布 ...