当前位置: 首页 > news >正文

深圳外贸网站制作公司/今日重庆重要消息

深圳外贸网站制作公司,今日重庆重要消息,电子邮箱怎么申请,做视频的免费软件有哪些今日任务 209.长度最小子数组; 59.螺旋矩阵|| 58.区间和 44.开发商购买土地 209.长度最小的子数组 题目建议: 本题关键在于理解滑动窗口,这个滑动窗口看文字讲解 还挺难理解的,建议大家先看视频讲解。 拓展题目可以先不做。 题目链接&#xf…

今日任务

209.长度最小子数组; 59.螺旋矩阵|| 58.区间和 44.开发商购买土地

209.长度最小的子数组

题目建议: 本题关键在于理解滑动窗口,这个滑动窗口看文字讲解 还挺难理解的,建议大家先看视频讲解。 拓展题目可以先不做。

题目链接:. - 力扣(LeetCode)

文章讲解:代码随想录

视频讲解:拿下滑动窗口! | LeetCode 209 长度最小的子数组_哔哩哔哩_bilibili

    //连续: 滑动窗口public static int minSubArrayLen(int target, int[] nums) {if(nums == null || nums.length == 0){return 0;}int l=0,r=0;int minLen = Integer.MAX_VALUE;//计算前缀和int[] sumArr = new int[nums.length+1];sumArr[0] = nums[0];for(int i=1;i< nums.length;i++){sumArr[i] = nums[i] + sumArr[i-1];}//计算累加值最小while(l<=r && r <= nums.length-1){//当前滑动窗口内的和int curSum = l == 0 ? sumArr[r] : sumArr[r] - sumArr[l-1];//不满足条件,则窗口右端右移扩大范围if(curSum < target){r++;continue;}//满足条件,则窗口左端右移尝试缩小范围if(curSum >= target){minLen = Math.min(r-l+1,minLen);l++;continue;}}return minLen == Integer.MAX_VALUE ? 0:minLen;}
核心点:

        看到连续和的时候,优先想到的就是滑动窗口与前缀和,滑动窗口的题型,关键点需要理解什么情况下需要扩大/缩小窗口范围

59.螺旋矩阵II

题目建议: 本题关键还是在转圈的逻辑,在二分搜索中提到的区间定义,在这里又用上了。

题目链接:. - 力扣(LeetCode)

文章讲解:代码随想录

视频讲解:一入循环深似海 | LeetCode:59.螺旋矩阵II_哔哩哔哩_bilibili

class Solution {public int[][] generateMatrix(int n) {int[][] res = new int[n][n];//共几圈int totalRound = n%2 + n/2;dfs(res,1,totalRound,1,n);return res;}/*** 如图二维数组对应的坐标为(x,y)* +-----------------> x* | (0,0) (0,1) (0,2)* | (1,0) (1,1) (1,2)* ↓ (2,0) (2,1) (2,2)* y* @param res* @param start 起始值* @param width 正方形边长,初始为n,每缩小一圈边长减2* @param round 第几圈: 最外圈认为是第一圈*/public static void dfs(int[][] res,int round,int totalRound,int start,int width){if(round > totalRound){return;}int x = round-1;int y = round-1;int idxEnd = round+width-2;边长为1时,则需要设置中心值if(width == 1){res[x][y] = start;return;}//顶for (;y < idxEnd; y++) {res[round-1][y] = start++;}//右for (;x < idxEnd; x++) {res[x][idxEnd] = start++;}//底for (;y > round-1; y--) {res[idxEnd][y] = start++;}//左for (; x > round-1; x--) {res[x][y] = start++;}//width 边长每次都减2 --> 左边减一右边减一dfs(res,round+1,totalRound,start,width-2);}
}

核心点

        解题的关键在于几个关键点:

  1. 明确循环不变量原则或者是找到循环体
  2. 理解每层正方形的变成差值为2
  3. 拆分成 顶边(x不变y递增),右边(y不变x递增),底边(x不变y递减),左边(y不变x递减)
  4. 按着上面的原则将多层正方形的填空题比变成了单层正方形的填空题

58.区间和

前缀和是一种思维巧妙很实用 而且 很有容易理解的一种算法思想,大家可以体会一下

文章讲解:58. 区间和 | 代码随想录
题目描述

给定一个整数数组 Array,请计算该数组在每个指定区间内元素的总和。

输入描述

第一行输入为整数数组 Array 的长度 n,接下来 n 行,每行一个整数,表示数组的元素。随后的输入为需要计算总和的区间下标:a,b (b > = a),直至文件结束。

输出描述

输出每个指定区间内元素的总和。

输入示例
5
1
2
3
4
5
0 1
1 3
输出示例
3
9
提示信息

数据范围:
0 < n <= 100000

import java.util.Scanner;public class Main {public static void main (String[] args) {Scanner sc = new Scanner(System.in);//arr长度 lenint len = sc.nextInt();int[] arr = new int[len];//补充数组元素for(int i=0;i<len;i++){arr[i] = sc.nextInt();}int[] sum = new int[len];sum[0] = arr[0];//计算前缀和for(int i=1;i<len;i++){sum[i] = sum[i-1]+arr[i];}//输入范围int left,right;while(sc.hasNextInt()){left = sc.nextInt();right = sc.nextInt();int res = (left == 0) ? sum[right] : sum[right]- sum[left-1];System.out.println(res);}}
}
补充(Java ACM输入输出):
常用类
import java.util.Scanner;
常用API
//构造方法
//从文件中读取数据
//Scanner sc = new Scanner(File source);
//从输入流中读取数据
//Scanner sc = new Scanner(InputStream source);
//从字符串中读取数据
//Scanner sc = new Scanner(String source);
//直接接受系统控制台的输入
Scanner sc = new Scanner(System.in);//数据读取
//读取字符串,遇到空格或换行符停止
sc.next();
//读取整数
sc.nextInt();
//读取双精度浮点数
sc.nextDouble();
//读取一行字符串,包括换行符
sc.nextLine();//数据判断
//判断是否有下一个字符串
sc.hasNext();
//判断是否有下一个整数
sc.hasNextInt();
//判断是否有下一个双精度浮点数
sc.hasNextDouble();
//方法来判断是否还有下一行输入
sc.hasNextLine();

44.开发商购买土地

44. 开发商购买土地 | 代码随想录

【题目描述】

在一个城市区域内,被划分成了n * m个连续的区块,每个区块都拥有不同的权值,代表着其土地价值。目前,有两家开发公司,A 公司和 B 公司,希望购买这个城市区域的土地。

现在,需要将这个城市区域的所有区块分配给 A 公司和 B 公司。

然而,由于城市规划的限制,只允许将区域按横向或纵向划分成两个子区域,而且每个子区域都必须包含一个或多个区块。

为了确保公平竞争,你需要找到一种分配方式,使得 A 公司和 B 公司各自的子区域内的土地总价值之差最小。

注意:区块不可再分。

【输入描述】

第一行输入两个正整数,代表 n 和 m。

接下来的 n 行,每行输出 m 个正整数。

输出描述

请输出一个整数,代表两个子区域内土地总价值之间的最小差距。

【输入示例】

3 3 1 2 3 2 1 3 1 2 3

【输出示例】

0

【提示信息】

如果将区域按照如下方式划分:

1 2 | 3 2 1 | 3 1 2 | 3

两个子区域内土地总价值之间的最小差距可以达到 0。

【数据范围】:

  • 1 <= n, m <= 100;
  • n 和 m 不同时为 1。
import java.util.Scanner;public class Main {public static void main(String[] args){Scanner sc = new Scanner(System.in);//System.out.println("输入n");int n = sc.nextInt();//System.out.println("输入m");int m = sc.nextInt();int[][] arr = new int[n][m];for (int i = 0; i < n; i++) {//System.out.println("输入第"+(i+1)+"行");for (int j = 0; j < m; j++) {arr[i][j] = sc.nextInt();}}//二维数组所有元素和int total = 0;//计算前缀和int[][] sum = new int[n][m];for (int i = 0; i < n; i++) {sum[i][0] = arr[i][0];total += m == 1 ? sum[i][0]:0; }for (int i = 0; i < n; i++) {for (int j = 1; j < m; j++) {sum[i][j] = sum[i][j-1] + arr[i][j];total += ((j == (m-1)) ? sum[i][j] : 0);}}//计算最终输出结果int min = Integer.MAX_VALUE;//按y轴切割for (int i = 0; i < n-1; i++){int top = sumY(sum,i,m);int down = total-top;min = Math.min(min,Math.abs(top-down));}//按x轴切割for (int i = 0; i < m-1; i++){int left = sumX(sum,i,n);int right = total-left;min = Math.min(min,Math.abs(left-right));}System.out.println(min);}/*** 横向统计 -- 累加每个数组的最后一个元素* @return*/public static int sumY(int[][] sum,int y,int m){int res = 0;for (int i = 0; i <= y; i++) {res += sum[i][m-1];}return res;}/*** 纵向统计* @return*/public static int sumX(int[][] sum,int x,int n){int res = 0;for (int i = 0; i < n; i++) {res += sum[i][x];}return res;}
}

总结

       数组通常的考察方向有三点:

  1. 二分法
  2. 双指针(快慢指针/对向指针/滑动窗口)
  3. 关键是需要搞清楚什么节点需要移动哪个指针
  4. 循环不变量原则(最小循环体)
  5. 前缀和

相关文章:

代码随想录算法训练营第二天 |209.长度最小子数组; 59.螺旋矩阵|| ; 前缀和

今日任务 209.长度最小子数组; 59.螺旋矩阵|| 58.区间和 44.开发商购买土地 209.长度最小的子数组 题目建议&#xff1a; 本题关键在于理解滑动窗口&#xff0c;这个滑动窗口看文字讲解 还挺难理解的&#xff0c;建议大家先看视频讲解。 拓展题目可以先不做。 题目链接&#xf…...

Go语言基础--数据类型(整型、字符型)

转义字符 常用的转义字符有如下: 1)\t : 表示一个制表符&#xff0c;通常使用它可以排版。 2)\n&#xff1a;换行符 3)\\&#xff1a;一个\ 4) \"&#xff1a;一个" 5)\r&#xff1a;一个回车 数据类型概述 在 Go 编程语言中&#xff0c;数据类型用于声明函数和变量…...

SpringBoot配置--Profile

目录 使用profile 的原因&#xff1f; proflie 的配置方式 多profile文件方式 profile 激活方式 1 配置文件 2 命令行参数 小结 使用profile 的原因&#xff1f; 用来完成不同环境下&#xff0c;配置动态切换功能的&#xff08;具体什么意思呢&#xff1f;假设你在A电脑…...

在Go中理解栈和先进先出原则

Go是一种功能强大的编程语言&#xff0c;提供了丰富的数据结构和算法。堆栈是计算机科学中的基本数据结构之一。在本博文中&#xff0c;我们将探讨如何在 Go 中实现和使用堆栈&#xff0c;以及堆栈如何遵循先进先出 (FIFO) 原则。 首先&#xff0c;让我们来看看堆栈是什么以及它…...

Ted靶机渗透测试

一、靶机下载地址 Ted: 1 ~ VulnHub 二、信息收集 1、主机发现 # 使用命令 nmap 192.168.145.0/24 -sn | grep -B 2 "00:0C:29:E2:36:FA" 2、端口扫描 # 使用命令 nmap 192.168.145.214 -p- -sV 3、指纹识别 # 使用命令 whatweb "http://192.168.145.214&…...

【chart.js】折线图给点添加点击事件

var mychart new Chart( ctx,{ type:line", … options:{ hover:{ // 此处最重要&#xff0c;决定是否能选中绑定的点 mode:“nearest” } &#xff0c; onClick:function(event,elements){ // 此为 被点击 的点 firstelement elements[0] // 这个点 属于第几个数据集合…...

旧手机NAS方案

这里写目录标题 1、参考2、alpine-term-v16.0-release.apk下载安装3、电脑端ssh连接3、安装docker3.1 网络配置3.2 配置APK源 1、参考 【Docker与Termux】闲置旧安卓手机上的NAS无缝部署方案 https://blog.csdn.net/AnRanGeSi/article/details/138717589 【Alpine Term】Andr…...

Secure CRT 9.x版本高亮着色配置文件

Secure CRT的网络配置文件高亮显示&#xff0c;还在完善&#xff0c;逐渐适配不同厂商 设备名字自动蓝色高亮显示设备接口名高亮显示IPv4地址、IPv6地址、MAC地址高亮显示掩码、反掩码高亮显示设备SN号高亮显示接口状态、设备状态等高亮显示各路由协议高亮显示 【下载地址】效果…...

kafka无法启动,提示连接zookeeper超时

想必不少人都遇到过这种场景&#xff0c;明明昨天环境还好好的&#xff0c;今天怎么就不行了呢&#xff1f;关键是这种情况&#xff0c;有时候连重启大法都不管用了&#xff0c;顿时陷入了毫无头绪的茫然中。。。 好了&#xff0c;聊回话题本身&#xff0c;因为升级程序&#x…...

mysql5.7.20升级5.7.44

近期安全测试mysql5.7.20有很多的漏洞&#xff0c;考虑升级到5.7.44 问题1&#xff1a;下载5.7.44的版本&#xff1a; 选择安装版本&#xff0c;或者zip解压版本&#xff0c;看上一篇文章 我选择了安装版本&#xff1b; 问题2&#xff1a;做好现场data文件的备份&#xff1…...

支持S/MIME证书的邮件客户端有哪些?

S/MIME证书&#xff0c;也叫做邮件安全证书&#xff0c;支持安全/多用途互联网邮件扩展协议&#xff08;S/MIME协议&#xff09;&#xff0c;是通过加密和数字签名来确保电子邮件的安全性、保密性和完整性的数字证书。GDPR、HIPAA、FDA等多个行业都要求邮件发送方在发送邮件时对…...

uniapp本地打包app安装说明

uniapp本地打包app安装说明 目录 uniapp本地打包app安装说明一、打包说明1.HBuilder X 生成本地打包资源2.Android Studio和App离线SDK环境准备2.1 下载Android Studio和 App离线SDK2.2 资源替换2.3 id属性值修改。2.4 添加provider信息到AndroidManifest.xml中的<applicati…...

ddos造成服务器瘫痪后怎么办

在服务器遭受DDoS攻击后&#xff0c;应立即采取相应措施&#xff0c;包括加强服务器安全、使用CDN和DDoS防御服务来减轻攻击的影响。rak小编为您整理发布ddos造成服务器瘫痪后怎么办。 当DDoS攻击发生时&#xff0c;首先要做的是清理恶意流量。可以通过云服务提供商提供的防护措…...

重磅官宣!追光少年【彭禹锦】荣担任中国美育促进网amp;IPA美育中国行代言人

在美育事业蓬勃发展的今天&#xff0c;一位年仅15岁的少年以其非凡的艺术才华和积极向上的精神风貌&#xff0c;成为了万众瞩目的焦点。中国美育促进网与IPA美育中国行正式宣布&#xff0c;才华横溢、正能量满满的追光少年彭禹锦受邀担任“中国美育促进网&IPA美育中国行”代…...

Python 解析GIS的SHP文件

工作中需要处理一些GIS数据&#xff0c;在 Python 中解析地理信息系统 (GIS) 的 Shapefile (.shp) 文件通常可以通过 geopandas 库来完成。geopandas 是基于 pandas 的一个扩展库&#xff0c;它支持地理空间数据的操作和分析。 下面是一个简单的示例&#xff0c;展示如何使用 …...

大模型微调--文章3

原文地址 链接&#xff1a;https://zhuanlan.zhihu.com/p/635848732 思考题 问题1&#xff1a;p-tuning为了解决什么问题&#xff1f;&#xff08;解决&#xff09; 答案&#xff1a;该方法的提出主要是为了解决这样一个问题&#xff1a;大模型的Prompt构造方式严重影响下游任…...

游戏测试中需求分析的本质

游戏测试大不同 1.游戏功能模块介绍1.1. 登录模块1.2. 注册模块1.3. 故事情节模块1.4. 动画模块1.5. 音频模块1.6. 结束界面模块1.7. 网络模块1.8. 数据库模块 2.需求文档编写2.1需求的定义2.2需求分类2.3需求分析目标 3.测试用例编写3.1测试用例的定义3.2测试用例拆解包含测试…...

2024零基础入行软件测试全网最全攻略

很多朋友想要入行软件测试&#xff0c;但是都不知道该怎么学。 抽个时间简单的给大家说下&#xff0c;对于0基础的朋友&#xff0c;应该怎么去学习软件测试。 学习软件测试有2条路可以选。 最省事的当然是找个靠谱的培训机构去培训啦&#xff0c;你就什么都不用想了&#xff0c…...

spring-boot-starter-quartz 自动化配置解析

版本 spring-boot:3.3.4 源码解析 依赖包 spring-boot-starter-quartz 的作用为引入相关依赖&#xff1a; spring-boot-starterspring-context-supportspring-txquartz 自动化配置类 依赖&#xff1a;spring-boot-autoconfigure:3.2.4 文件&#xff1a;org.springframewo…...

DM8 数据库查询版本号以及授权到期时间SQL

1.查看操作系统信息 [root@localhost ~]# cat /etc/.kyinfo [dist] name=Kylin milestone=Server-V10-GFB-Release-ZF9_01-2204-Build03 arch=arm64 beta=False time=2023-01-09 11:04:36 dist_id=Kylin-Server-V10-GFB-Release-ZF9_01-2204-Build03-arm64-2023-01-09 11:04:…...

算法【Java】—— 双指针算法

双指针算法 常见的双指针有对撞指针&#xff0c;快慢指针以及前后指针&#xff08;这个前后指针是指两个指针都是从从一个方向出发&#xff0c;去往另一个方法&#xff0c;也可以认为是小学学习过的两车并行&#xff0c;我也会叫做同向指针&#xff09;&#xff0c;在前后指针…...

【Python快速入门和实践013】Python常用脚本-目标检测之按照类别数量划分数据集

一、功能介绍 这段代码实现了从给定的图像和标签文件夹中分割数据集为训练集、验证集和测试集的功能。以下是代码功能的总结&#xff1a; 创建目标文件夹结构&#xff1a; 在指定的根目录&#xff08;dataset_root&#xff09;下创建images和labels两个文件夹。在这两个文件夹下…...

C++ Primer 总结索引 | 第十八章:用于大型程序的工具

1、大规模应用程序的特殊要求包括&#xff1a; 在独立开发的子系统之间 协同处理错误的能力使用各种库&#xff08;可能包含独立开发的库&#xff09;进行 协同开发的能力对比较复杂的应用 概念建模的能力 对应 异常处理、命名空间和多重继承 1、异常处理 1、异常处理机制 …...

Python实现GAN(生成对抗网络)图像修复算法

目录 1. GAN简介与图像修复2. PyTorch和CUDA简介3. 数据加载与预处理3.1 安装依赖3.2 数据加载3.3 数据遮挡4. 构建GAN图像修复模型4.1 生成器4.2 判别器5. 训练GAN模型5.1 损失函数与优化器5.2 训练循环6. 测7. 实现GUI进行图像修复8. 总结与扩展扩展方向:1. GAN简介与图像修…...

java语言中的websocket

你好&#xff01;我是TensGPT&#xff0c;一个由TensGPT团队开发的AI助手。我可以帮助你了解和使用Java语言中的WebSocket。如果你有任何问题或需要示例代码&#xff0c;请告诉我。 ### 什么是WebSocket&#xff1f; WebSocket是一种在单个TCP连接上进行全双工通信的协议。它被…...

ASP.NET在线交流论坛管理系统

ASP.NET在线交流论坛管理系统 说明文档 运行前附加数据库.mdf&#xff08;或sql生成数据库&#xff09; 主要技术&#xff1a; 基于asp.net架构和sql server数据库 用户功能有个人信息管理 帖了信息管理 意见反馈信息管理 点赞管理 收藏管理 后台管理员可以进行用户管理 …...

【Kubernetes】身份认证与鉴权

一&#xff0c;认证 所有 Kubernetes 集群有两类用户&#xff1a;由Kubernetes管理的ServiceAccounts(服务账户)和(Users Accounts)普通账户。 两种账户的区别&#xff1a; 普通帐户是针对(人)用户的&#xff0c;服务账户针对Pod进程普通帐户是全局性。在集群所有namespaces…...

数据集与数据库:有什么区别?

数据集和数据库是我们在处理数据时经常听到的两个常用词。虽然它们听起来很相似&#xff0c;但它们具有不同的特征并用于不同的用途。本文深入探讨数据集和数据库之间的主要区别&#xff0c;探索了它们的结构、数据类型和各种其他功能&#xff0c;以帮助您做出明智的决定&#…...

BurpSuite

如果只能用一个Web渗透工具&#xff0c;我选BurpSuite。 Web应用程序&#xff08;Web Application&#xff09; 不同于传统的静态网站所有程序的特点是接收、处理用户输入并返回结果服务器端是个程序&#xff0c;需要程序代码实现业务功能&#xff08;java、php、asp.nse&…...

NetApp数据恢复—NetApp存储误删除文件如何恢复数据?

NetApp数据恢复环境&故障&#xff1a; 某公司一台NetApp存储&#xff0c;该存储中有24块磁盘。 工作人员误删除了NetApp存储中一个文件夹&#xff0c;文件夹中有非常重要的数据。 数据恢复工程师在现场对该存储进行了初检。虽然这个文件夹被删除很长时间&#xff0c;但是根…...