代码随想录


一. 数组的理论基础

概念:数组是存放在连续内存空间上的相同类型数据的集合

特点:(1)数组可以通过下标进行访问对应的数据并且下标是从0开始的 -> 随机访问;(2)数组内存空间的地址是连续的 -> 移动数据较为复杂

 注意:

(1)使用C++的时候要注意区别 vector 和 array,vector 的底层实现是 array,但是 vector 可以实现自动扩展的容器 -> 适用于大小不确定的情况,但是 array 是适用于固定大小的情况,使用于编译期已知大小、性能要求高的场景

(2)C++中二维数组在地址空间上是连续的

Java 是没有指针的,同事也不对程序员暴露地址,由Java虚拟机来实现,是以下这种形式

二. 题目

2.1 LC704.二分查找

class Solution {
public:int search(vector<int>& nums, int target) {int left = 0;int right = nums.size() -1;while(left <= right){int mid = left + ((right - left) >> 1);if(nums[mid] < target){left = mid +1;}else if(nums[mid] > target){right = mid - 1;}else{return mid;}}return -1;}
};

 

2.2 LC27.移除元素

class Solution {
public:int removeElement(vector<int>& nums, int val) {int slow = 0;int fast = 0;while(fast < nums.size()){if(nums[fast] == val){fast++;}else{nums[slow] = nums[fast];slow++;fast++;}}return slow;}
};

2.3 LC977.有序数组的平方

class Solution {
public:vector<int> sortedSquares(vector<int>& nums) {int left = 0;int right = nums.size() -1;vector<int> ans(nums.size());int pos = nums.size() -1;while(left <= right){int leftRes = pow(nums[left], 2);int rightRes = pow(nums[right], 2);if(leftRes <= rightRes){ans[pos] = rightRes;right--;}else{ans[pos] = leftRes;left++;}pos--;}return ans;}
};

2.4 LC209.长度最小的子数组

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int start = 0;int end = 0;int sum = 0;int ans = INT_MAX;while(start <= end && end < nums.size()){sum += nums[end];while(sum >= target){ans = min(ans, end - start + 1);sum -= nums[start];start++;}end++;}return ans==INT_MAX?0:ans;}
};

2.5 LC59.螺旋矩阵||

class Solution {
public:vector<vector<int>> generateMatrix(int n) {vector<vector<int>> matrix(n, vector<int>(n));int idx = 0;int left = 0;int right = n-1;int up =0;int below = n-1;while(idx <= pow(n, 2)){for(int i = left; i <= right; i++){idx++;matrix[up][i] = idx;}if(++up > below)    break;for(int i =up; i<=below;i++){idx++;matrix[i][right] = idx; }if(--right < left)  break;for(int i=right;i>=left;i--){idx++;matrix[below][i] = idx;}if(--below < up)    break;for(int i=below;i>=up;i--){idx++;matrix[i][left] = idx;}if(++left > right) break;}return matrix;}
};

2.6 KC58.区间和

#include<iostream>
#include<vector>
using namespace std;int main(){int a, b, n;cin >> n;vector<int> arr(n);vector<int> presum(n);for(int i=0;i<n;i++){// cin >> arr[i];scanf("%d", &arr[i]);if(i == 0){presum[i] = arr[i];}else{presum[i] = presum[i-1] + arr[i];}}while(~scanf("%d%d",&a,&b)){int sum = 0;if(a == 0){sum = presum[b];}else{sum = presum[b] - presum[a-1];}printf("%d\n", sum);}
}

注意:这里的 ~scanf 的写法可以记录下来

2.7 KC44.开发商购买土地

#include<iostream>
#include<vector>
#include <climits>
using namespace std;int main(){int m, n;cin >> m >> n;int sum = 0;vector<vector<int>>vec(m, vector<int>(n,0));for(int i=0;i<m;i++){for(int j=0;j<n;j++){cin >> vec[i][j];sum += vec[i][j];}}vector<int> horizontal(m, 0);for(int i=0;i<m;i++){for(int j=0;j<n;j++){horizontal[i] += vec[i][j];}}vector<int> vertical(n, 0);for(int j=0;j<n;j++){for(int i=0;i<m;i++){vertical[j] += vec[i][j];}}int res = INT_MAX;int hdiff = 0;for(int i=0;i<m;i++){hdiff += horizontal[i];res = min(res, abs(sum - 2* hdiff));}int vdiff = 0;for(int j=0;j<n;j++){vdiff += vertical[j];res = min(res, abs(sum - 2*vdiff));}cout << res << endl;
}

 总结:主要用到的是双指针、滑动窗口、前缀和

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

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

相关文章

Netty内存池核心PoolArena源码解析

PoolArena 是 Netty 内存池化机制的核心组件之一&#xff0c;它负责管理一整块或多块内存&#xff08;PoolChunk&#xff09;&#xff0c;并将这些内存分配给应用程序。每个 PoolArena 实例都与一个特定的线程相关联&#xff08;通过 PoolThreadCache&#xff09;&#xff0c;或…

echarts-for-react 日历热力图渲染导致白屏 踩坑记录

先说结果&#xff0c;补上了一行tooltip.trigger后能正常渲染了。 报错情况&#xff1a; 在页面中添加了一个日历热力图后&#xff0c;一渲染它就白屏&#xff0c;控制台报错如下&#xff1a; echarts-for-react版本是当前最新的3.0.2&#xff0c;尝试debug但没看懂源码这里是…

SpringBoot项目启动时自动加载数据到Redis的完整实现方案,用于存储字典,定时任务,登录用户等

一、基础配置 ‌在pom.xml中添加必要依赖&#xff1a; <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <dependency><groupId>com.baomi…

python:使用 OpenAI CLIP 模型进行图像与文本的语义匹配,并用彩虹色带可视化 CLIP 模型的相似度矩阵

作者&#xff1a;CSDN _养乐多_ 本文将介绍如何使用 OpenAI 的 CLIP 模型来实现图像与文本之间的语义匹配。代码使用 Python 语言&#xff0c;加载多个图像与类别文本&#xff0c;并通过计算余弦相似度判断每张图片最匹配的文本标签。 结果如下图所示&#xff0c; 文章目录 …

微服务链路追踪在生产环境问题定位中的实战经验

微服务链路追踪在生产环境问题定位中的实战经验 在当今复杂的系统架构中&#xff0c;微服务之间相互调用形成的链路往往变得极其复杂。一旦出现问题&#xff0c;仅凭日志和监控信息常常难以迅速定位根因。链路追踪技术因此成为生产环境中不可或缺的工具&#xff0c;能够帮助我…

正点原子——直流无刷电机-霍尔传感基本实现流程

直流无刷电机-霍尔传感实现流程 初始化TIM以及IO 霍尔状态读取函数 uint32_t hallsersor(void) {uint32_t state 0;if(HAL_GPIO_ReadPin(HALL1_TIM_CH1_GPIO,HALL_TIM_CH1_PIN)!RESET){state |0x01;}if(HAL_GPIO_ReadPin(HALL1_TIM_CH2_GPIO,HALL_TIM_CH2_PIN)!RESET){stat…

小白的进阶之路系列之十七----人工智能从初步到精通pytorch综合运用的讲解第十部分

NLP 从零开始:使用字符级 RNN 生成姓名 这是我们“NLP 从零开始”系列三部分教程中的第二部分。在第一个教程中,我们使用了 RNN 将姓名分类到其语言来源。这次我们将反过来,从语言生成姓名。 > python sample.py Russian RUS Rovakov Uantov Shavakov> python sampl…

思辨场域丨AR技术如何重塑未来学术会议体验?

毫无疑问&#xff0c;增强现实&#xff08;AR&#xff09;已成为科技浪潮中最澎湃的浪花之一。当Pokemon Go点燃全球热情&#xff0c;我们首次大规模体验到数字精灵与现实街景的奇妙交融。这不仅是游戏革命&#xff0c;更是一个强烈的信号&#xff1a;虚实共生的交互时代已轰然…

医学数据分析实战:冠心病发病因素可视化

一、数据加载与基本信息检查 #例9.5 import numpy as np import pandas as pd import matplotlib.pyplot as plt import seaborn as sns import warnings#引入第三方库plt.rcParams[font.sans-serif]=[SimHei] #用来正常显示中文标签 warnings.filterwarnings(ignore) #防止…

Proteus8.0 打开前期版本的操作方法

1.打开Proteus8.0 2. 打开菜单File->Import legacy Project 3.在Import Legacy Project 点击Browse按钮 4.选择要打开的例子目录 5.打开*.dsn文件 6.点击Import 7.导入成功 点击运行即可

【innovus基础】- 对某根线单独route

在某些特殊需求场景&#xff0c;我们可能需要对某些net进行单独的route&#xff0c;方法如下&#xff1a; 1、打开design browser&#xff0c;选择对应net&#xff1a;&#xff08;或者使用selectNet命令&#xff09; 2、Route → nano Route → 勾选selectNet only 可以看到…

【Linux】network网络配置

目录 1、介绍2、网络配置【1】查看【2】说明 3、工作流程【1】启动以太网接口【2】关闭接口时反向执行 4、现代替换方案 1、介绍 linux中network网络服务的核心配置位于/etc/sysconfig/network-scripts/目录下。它们共同构成了网络接口的管理框架&#xff0c;负责处理网络接口…

深入解析 Taro 项目结构:从入门到精通

在现代前端开发中&#xff0c;跨平台开发框架变得越来越重要。Taro 作为一款由京东凹凸实验室推出的多端统一开发框架&#xff0c;支持编译到微信小程序、支付宝小程序、百度小程序、H5、React Native 等多个平台&#xff0c;极大地提高了开发效率。然而&#xff0c;要充分发挥…

零基础开始的网工之路第二十一天------系统安全基线和系统加固

目录 一、系统安全基线 1、账户与认证安全 2、文件与目录权限 3、SSH服务安全 4、网络与服务配置 5、日志与审计 6、内核参数加固 7、更新与补丁 8、安全模块配置 9、SUID/SGID文件检查 10、默认权限控制&#xff08;umask&#xff09; 二、系统安全加固 1、账户与…

Log4j 和 Log4j2的比较

以下是 Log4j&#xff08;通常指 Log4j 1.x&#xff09;与 Log4j2 的核心对比分析&#xff0c;结合架构、性能、功能及适用场景&#xff0c;帮助开发者做出合理选择&#xff1a; &#x1f4ca; 一、架构与设计 特性Log4j 1.xLog4j2分析架构模型单模块设计&#xff0c;耦合度高…

说说 Springboot 的启动流程?

Spring Boot 的启动流程是一个相对复杂但有序的过程&#xff0c;它涉及多个组件和步骤的协同工作。以下是 Spring Boot 启动流程的详细解析&#xff1a; 一、初始化阶段 启动入口 Spring Boot 应用的启动入口通常是一个包含 main 方法的类&#xff0c;该类上标注了 SpringBoot…

从服务器收到预料之外的响应。此文件可能已被成功上传。请检查媒体库或刷新本页

如果php.ini已经加入了如下的内容还是报错 &#xff1a; upload_max_filesize 1024M post_max_size 1024M 那就是因为阿帕奇导致&#xff1a;

10、java语法糖

编译期处理&#xff1a;语法糖&#xff08;即java编译器把。java的源码编译成。class字节码的过程中&#xff0c;自动生成和转换的一些代码&#xff0c;主要是为了减轻程序员的负担&#xff0c;算是java编译器给我们的一个额外福利-给糖吃&#xff09; 默认构造器&#xff1a;…

在Vscode中安装Sass并配置

在Vscode中安装Sass并配置 sass简介安装Sass插件配置sass插件编写sass使用Sass sass简介 Sass&#xff08;Syntactically Awesome Style Sheets,英文官方文档 &#xff09;是一种CSS预处理器&#xff0c;扩展了CSS的功能并提供了更高效的样式表编写方式。它兼容所有CSS版本&am…

深入解析 MySQL 并发控制:读写锁、锁粒度与高级优化

深入解析 MySQL 并发控制:读写锁、锁粒度与 InnoDB 实现细节 在高并发数据库应用中,确保数据一致性的同时最大化性能是永恒的挑战。MySQL 通过精巧的 锁机制(Locking) 和 多版本并发控制(MVCC) 来解决这个问题。本文聚焦于锁机制的核心:读写锁(共享/排他锁) 和 锁粒度…