【强训笔记】day24

NO.1
在这里插入图片描述
思路:递归。

代码实现:

class Solution {
public:bool IsBalanced_Solution(TreeNode* pRoot) {return dfs(pRoot)!=-1;}int dfs(TreeNode* root){if(root==nullptr) return 0;int left=dfs(root->left);if(left==-1) return -1;int right=dfs(root->right);if(right==-1) return -1;return abs(left-right)<=1?max(left,right)+1:-1;}
};

NO.2
在这里插入图片描述
算法思路:
⼆维前缀和矩阵的应⽤。
a. 初始化⼆维前缀和矩阵;
b. 枚举所有的⼦矩阵,求出最⼤⼦矩阵。

代码实现:

#include <iostream>
using namespace std;
const int N = 110;
int n;
int dp[N][N];
int main()
{int x;cin >> n;for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){cin >> x;dp[i][j] = dp[i - 1][j] + dp[i][j - 1] - dp[i - 1][j - 1] + x;}}int ret = -127 * N;for (int x1 = 1; x1 <= n; x1++){for (int y1 = 1; y1 <= n; y1++){for (int x2 = x1; x2 <= n; x2++){for (int y2 = y1; y2 <= n; y2++){ret = max(ret, dp[x2][y2] - dp[x1 - 1][y2] - dp[x2][y1 -1] + dp[x1 - 1][y1 - 1]);}}}}cout << ret << endl;return 0;
}

NO.3
在这里插入图片描述
思路:滑动窗口,分别统计字符串中和窗口内0和1的数量,当窗口内字符串的数量为原字符串的一半,且该窗口内0和1的数量是外面字符串中0和1数量的一半时,就有两种方法。

代码实现:

#include <iostream>
#include <string>using namespace std;
int n;
string s;
int main()
{cin >> n >> s;int sum[2] = { 0 }; // 统计字符串中所有 0 和 1 的个数for (auto ch : s){sum[ch - '0']++;}int left = 0, right = 0, ret = 0, half = n / 2;int count[2] = { 0 }; // 统计窗⼝内 0 和 1 的个数while (right < n - 1) // 细节问题{count[s[right] - '0']++;while (right - left + 1 > half){count[s[left++] - '0']--;}if (right - left + 1 == half){if (count[0] * 2 == sum[0] && count[1] * 2 == sum[1]){ret += 2;}}right++;}cout << ret << endl;return 0;
}

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

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

相关文章

Linux信号机制与docker应用

Linux任务终止信号 在linux系统中&#xff0c;为了终止任务&#xff0c;一般情况下&#xff0c;可能会涉及如下所示的几种信号&#xff1a; SIGTERM SIGTERM是终止命令kill默认的终止信号。此信号是由应用程序捕获的&#xff0c;使用SIGERM也让程序有机会再退出之前做好清理…

Vulnhub - AI-WEB-1.0靶机教程

目录 站点信息收集 c段扫描 端口扫描 目录扫描 漏洞利用 使用 burp 抓包 查询数据库名 查询数据库下的表 查询表中的字段名 查询字段中的数据 --os-shell 上传一句话木马 下载地址&#xff1a;https://download.vulnhub.com/aiweb/AI-Web-1.0.7z 我们从站点信息收…

【哈希】闭散列的线性探测和开散列的哈希桶解决哈希冲突(C++两种方法模拟实现哈希表)(1)

&#x1f389;博主首页&#xff1a; 有趣的中国人 &#x1f389;专栏首页&#xff1a; C进阶 &#x1f389;其它专栏&#xff1a; C初阶 | Linux | 初阶数据结构 小伙伴们大家好&#xff0c;本片文章将会讲解 哈希函数与哈希 之 闭散列的线性探测解决哈希冲突 的相关内容。 如…

Day19学习Java

什么是注解 java.annotation包 Annotation是从JDK1.5开始引入的新技术&#xff0c;注解即可以对程序员解释又可以对程序解释 注解与注释的区别 注释&#xff1a;对程序员解释代码信息 注解&#xff1a;对程序和程序员解释代码信息 注解的所用 不是程序本身&#xff0c;可以…

web会话跟踪(JWT是什么)

web会话跟踪(JWT是什么): 一.使用会话跟踪的原因&#xff1a; 因为http请求是无状态&#xff0c;一次请求响应结束后&#xff0c;就结束了&#xff0c;下一次再向服务器端发送请求&#xff0c;服务器并不知道是谁向他发送的 所以我们需要对整个会话过程进行跟踪 二.token: …

SpringBoot 配置Druid数据源及mysql

SpringBoot 配置Druid数据源及mysql 本文使用 druid-spring-boot-starter 方式 <dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.1.22</version> </dependency>&…

Echarts圆环图偏移后 中心文字居中对齐实现

像上图中这样圆环图并不在div的中间时&#xff0c;中心的文本需要居中展示 一开始用left百分比但数据一旦变长或变短就会偏移 像这样 实在是太不美观了 所以我们这里使用动态的left通过文本的长度来计算 /*** 计算文本宽度* param {String|Number} text* param {String} font*…

js之图片上传

话不多说&#xff0c;直接上干货&#xff0c;注释在代码里面 下面是效果图和代码 <!DOCTYPE html> <html lang"zh"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-sca…

[算法][数字][leetcode]2769.找出最大的可达成数字

题目地址 https://leetcode.cn/problems/find-the-maximum-achievable-number/description/ 题目描述 实现代码 class Solution {public int theMaximumAchievableX(int num, int t) {return num2*t;} }

第97天:权限提升-Web 权限权限划分源码后台中间件第三方数据库等

前置知识 具体有哪些权限需要我们了解掌握的 后台权限&#xff0c;网站权限&#xff0c;数据库权限&#xff0c;接口权限&#xff0c;系统权限&#xff0c;域控权限等 以上常见权限获取方法简要归类说明 后台权限&#xff1a;SQL 注入,数据库备份泄露&#xff0c;默认或弱口…

Qt | 内容边距(ContentsMargins)、间距(spacing)和 QSpacerItem 类

01、上节回顾 Qt | 布局管理器基础(QLayout)Qt | 布局部件拉伸(Stretch)原理及大小策略

Python | Leetcode Python题解之第104题二叉树的最大深度

题目&#xff1a; 题解&#xff1a; class Solution:def maxDepth(self, root: TreeNode) -> int:if not root: return 0queue, res [root], 0while queue:tmp []for node in queue:if node.left: tmp.append(node.left)if node.right: tmp.append(node.right)queue tmp…

Mybatis入门——其他查询操作和数据库连接池(4)

目录 一、多表查询 二、#{} 和 ${} 1、#{} 和 ${} 的使用 &#xff08;1&#xff09;Integer类型的参数 #{} 的使用 ${} 的使用 &#xff08;2&#xff09;使用String类型的参数 #{} 的使用 ${} 的使用 小结&#xff1a; 2、#{} 和 ${} 的区别 &#xff08;1&#…

太阳能语音监控杆(球机LED款)有什么用

传统监控设备依赖电力支持&#xff0c;在偏远地区和没有网络地区难以发挥其作用&#xff0c;而鼎跃安全的太阳能语音监控杆&#xff08;球机LED款&#xff09;在传统监控基础上&#xff0c;进行了全面优化&#xff0c;解决了无电无网区域使用受限的问题。 太阳能语音监控杆&am…

RSC英国皇家化学学会文献查找下载

英国皇家化学学会(Royal Society of Chemistry&#xff0c;简称RSC)是以促进全球化学领域研究发展与传播为宗旨的国际权威学术机构&#xff0c;是化学信息的一个重要宣传机关和出版商。RSC出版的期刊是化学领域的核心期刊&#xff0c;大部分被SCI和MEDLINE收录&#xff0c;如An…

浅谈JMeter作用域

浅谈JMeter作用域 JMeter是一款广泛使用的开源性能测试工具&#xff0c;它能够模拟多用户并发访问Web应用或其他系统的行为&#xff0c;以评估系统的性能和稳定性。在构建测试计划时&#xff0c;理解JMeter中的元件作用域与执行顺序至关重要。本指南将深入解析JMeter的作用域规…

K8s 1.25.4 高可用集群二进制部署(Runtime Containerd)

目录 一、集群环境准备 1.1 主机规划 1.2 软件版本 1.3 网络分配 二、集群部署 2.1主机准备 2.1.1 主机名设置 2.1.2 主机与IP地址解析 2.1.3 主机安全设置 2.1.4 交换分区设置 2.1.5 主机系统时间同步 2.1.6 主机系统优化 2.1.7 ipvs管理工具安装及模块加载 2.1…

腾讯云联络中心ivr调用自定义接口

1&#xff0c;java代码&#xff1a;http接口 RequestMapping(value "/getMsg5", method RequestMethod.POST) public Map<String, String> index(RequestBody Map<String, String> params) {String id params.get("id");HashMap<String…

渗透测试工具Cobalt strike-1.CS介绍与配置

Cobalt Strike是一款美国Red Team开发的渗透测试神器&#xff0c;常被业界人称为CS。最近这个工具大火&#xff0c;成为了渗透测试中不可缺少的利器。其拥有多种协议主机上线方式&#xff0c;集成了提权&#xff0c;凭据导出&#xff0c;端口转发&#xff0c;socket代理&#x…

目前无法解释的6个物理问题,每一个都困扰科学家很长时间

人类已经对宇宙有了大概的认知&#xff0c;不过即便如此&#xff0c;在宇宙中还有很多我们无法解释的物理问题&#xff0c;下面我们就一起来看看。 第一个无法解释的物理问题——虫洞真的存在吗&#xff1f; 虫洞最早是1916年由奥地利物理学家路德维希.费莱姆首次提出的&#…