Leetcode 学习记录 数组与字符串

news2025/6/28 15:37:33

基础不牢,地动山摇。这句话就是描述我现在的阶段,虽然这些天在csdn的练习上进展还比较顺利,但是内心还是没有底的。实话说,csdn的练习题和leetcode上的比起来,还是真的相差很远。可能是不和口味吧。我还是比较喜欢Leetcode,Leetcode唯一的缺点就是会员比较贵,其他的暂时还没有找到,我很喜欢那种深入浅出的讲解。

于是,继上次近乎捐赠了一年的会员后,我又入坑了。今天还是复习基础,还真的很有意思。

数组的pivot index

用嵌套循环实现

在这里插入图片描述
pivot index,翻译成中文是,中心索引。就是这个索引左边和右边的数字和是相等的,我注意到题目描述用到了stricly left/right,就是不包含中心索引自己哦,严格意义上的左边和右边。

说起来倒是不难,很快实现了一个版本,但是如图所示,内存消耗和用时都不理想。

class Solution {
    public int pivotIndex(int[] nums) {

        int i = 0;
        int index = 0, sumLeft = 0, sumRight = 0;

        while( i < nums.length){

            for( int j = i + 1; j < nums.length; j++){
                sumRight += nums[j];
            }

            if( i >= 1){
                sumLeft += nums[i-1];
            }

            if( sumLeft == sumRight){
                index = i;
                return index;
            }else{
                i ++;
                sumRight = 0;
            }

        }

        return index = -1;

    }
}

如上面的代码,我使用了嵌套循环,于是用时就很糟糕。

独立的两个循环的实现

嵌套循环的实现方法中,内部的循环的目的是计算sumRight。这里确实有更好的处理方式,可以放在while循环之外。在一开始计算出最初的sumRight,随后在while循环里逐步调整sumRight的值。具体代码如下:

class Solution {
    public int pivotIndex(int[] nums) {

        int i = 0;
        int index = 0, sumLeft = 0, sumRight = 0;

        for( int j = i + 1; j < nums.length; j++){
                sumRight += nums[j];
            }

        while( i < nums.length){

            if( i >= 1){
                sumLeft += nums[i-1];
            }

            if( sumLeft == sumRight){
                index = i;
                return index;
            }else if( i < nums.length - 1){
                sumRight -= nums[i+1];
                
            }
            i ++;

        }

        return index = -1;

    }
}

优化后的代码用时减少了很多,但是内存消耗还是很大。
在这里插入图片描述

优化变量

上面的代码中,可以优化掉一个dummy变量,index纯粹是为了好理解出现的,减少变量有助于减少内存消耗。

修改了代码后,内存消耗减少了0.3MB。其实也想过,循环要不要考虑一下精简,但是不想牺牲可理解性,现在这样很好理解。
在这里插入图片描述

最终的代码,虽然不尽完美,但是经过自己的思考,过程还是很有趣的。

class Solution {
    public int pivotIndex(int[] nums) {

        int i = 0;
        int sumLeft = 0, sumRight = 0;

        for( int j = i + 1; j < nums.length; j++){
                sumRight += nums[j];
            }

        while( i < nums.length){

            if( i >= 1){
                sumLeft += nums[i-1];
            }

            if( sumLeft == sumRight){
                
                return i;
            }else if( i < nums.length - 1){
                sumRight -= nums[i+1];
                
            }

            i ++;

        }

        return -1;



    }
}

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

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

相关文章

厉害了我们的“中国制造”,新能源“智造”强大到你想象不到

“中国制造”是近日的一大“热词”。 “中国制造”的新能源汽车花式“出海”&#xff0c;产销量连续7年位居全球首位&#xff1b;“中国制造”的过冬八件套反向海淘&#xff0c;订单暴增&#xff1b;“中国制造”的高铁首次全产业链“出海”…… 显而易见&#xff0c;当前是中国…

Unity导表工具Luban插件的数据加载原理与优化

文章目录1. 配置Luban并测试2. Luban 数据加载原理3. 根据工程进行懒加载优化3.1 增加公共接口与接口实现方法3.2 外部提供获取数据的方法3.3 对Luban中的导表模板进行修改4. 优化后测试如果初入坑&#xff0c;Luban配置可以参考宝鱼大佬的视频教程 强力配置工具luban使用教程【…

消除卡顿 mac MATLAB2022b m1/m2原生下载安装 教程

目录 1、版本说明 2、下载链接 2.1、百度网盘链接 2.2、官网下载链接 3、安装 1、版本说明 之前苦于安装matlab 2022b的Intel Rosetta转译版本&#xff0c;真的是明显感受到了卡顿&#xff0c;今天终于等到了2022b的原生版本&#xff0c;安装后占用10.09G内存。 ​​​​…

0096 克鲁斯卡尔算法,迪杰斯特拉算法

/* * 克鲁斯卡尔算法 * 1.用来求加权连通图的最小生成树的算法 * 2.思想&#xff1a;按照权值从小到大的顺序&#xff0c;选择n-1条边&#xff0c;并保证这n-1条边不构成回路 * 3.先构造一个只含n个顶点的森林&#xff0c;依权值从小到大从连通网中选择边加入到森林中 * …

web自动化测试-webdriver实现

webdriver实现基本语法1.Select下拉列表1.1下拉列表单选1.2下拉列表多选2.非Select下拉列表3.文件上传1.1input单个文件上传1.2input多个文件上传1.3非input文件上传1.Select下拉列表 1.1下拉列表单选 from selenium import webdriver from selenium.webdriver.support.ui imp…

GPU驱动及CUDA安装流程介绍

安装前准备工作 确认GPU型号和操作系统版本   准备gpu驱动和CUDA软件包   在nvidia官网进行驱动包下载   GPU驱动下载链接    Linux系统均选择 Linux 64-bit、CUDA Toolkit选择最新版本   注意该版本一定要大于等于cuda软件的版本。   选择CUDA及GPU驱动版本&#…

m基于matlab的TDSCDMA系统性能仿真

目录 1.算法概述 2.仿真效果预览 3.核心MATLAB代码预览 4.完整MATLAB程序 1.算法概述 TD-SCDMA的中文含义为时分复用同步码分多址接入&#xff0c;是由中国第一次提出、在无线传输技术(RTT)的基础上完成并已正式成为被ITU接纳的国际移动通信标准。这是中国移动通信界的一次…

解读ESSumm: Extractive Speech Summarization from Untranscribed Meeting

ESSumm: Extractive Speech Summarization from Untranscribed Meeting 从非转录会议中提取语音摘要&#xff08;非转录&#xff1a;原音频&#xff0c;没有转化为文本或者其他格式&#xff09; 论文地址 https://arxiv.org/abs/2209.06913 摘要 在本文中&#xff0c;我们为…

JS中的迭代器、可迭代对象、生成器

迭代器 迭代器&#xff08;iterator&#xff09;&#xff0c;是使用户在容器对象&#xff08;container&#xff0c;例如链表或数组&#xff09;上可以遍历访问的对象&#xff0c;使用该接口无需关心容器对象的内部实现细节。 从上面定义上来看&#xff0c;迭代器是帮助我们对…

SpringMVC 源码学习 返回值处理

SpringMVC中对返回值的数据基本分为两类&#xff1a; 1、响应数据 2、响应页面 一、响应数据 响应数据大多数都是将返回值的格式转换为JSON格式然后展示在页面或者保存i起来。 第一步&#xff1a;在SpringBoot中需要引入json场景 <dependency><groupId>org.sprin…

如何设计存储架构

步骤 步骤1&#xff1a;估算性能需求 任务 基于具体的业务场景来估算性能需求&#xff0c;包括存储量、读写性能等 挑战 不知道如何估算担心估算不准 步骤2&#xff1a;选择存储系统 任务 根据技术储备、方案优缺点选择合适的存储系统 挑战 不知道有哪些存储系统知道…

UG NX二次开发(C#)-UI Styler-批量选择点

1、前言 在设计UG NX的对话框界面时,有时需要选择点,在UI Styler编辑器中已经设置好了可以指定点选择按钮,这个点选择对话框是单选,不是多选的,如果想选择多个点,那么可以采用对象选择按钮,本文介绍下选择点的操作。 2、指定点按钮 2.1 设计UI Styler UG NX的UI Sty…

vscode中Emmet语法的使用

每篇博文的浪漫主义 【镰仓旅拍|落日绝景 极致画质|沉浸式旅行 FX3】 https://www.bilibili.com/video/BV1jg411Y7vC/?share_sourcecopy_web&vd_source385ba0043075be7c24c4aeb4aaa73352 镰仓旅拍|落日绝景 极致画质|沉浸式旅行 FX31.1快速生成HTML结构语法 生成标签直接…

想要彻底卸载Mac应用程序,还得要用这些方法才行

Mac电脑如果有太多无用的应用程序&#xff0c;很有可能会拖垮Mac系统的运行速度。因此&#xff0c;卸载电脑中无用的软件是优化Mac系统运行速度的最佳方式之一。Mac删除应用程序特别简单&#xff0c;长点击应用点击x&#xff0c;或是直接将应用拖进废纸篓。但是有一些应用长按没…

Qt——(详细)“项目在Debug构建环境下能运行而在Release构建环境下不能运行”解决方案之一,以及 禁用(黄色)警告

系列文章目录 提示&#xff1a; 文章目录系列文章目录前言环境一、问题准备工作——为了在Release环境下可以进行断点调试分析二、解决1、根据需求&#xff0c;对函数类型进行更改2、根据需求&#xff0c;在函数内添加“return [int]”延伸——“禁用警告”消除 变量 的“黄色感…

现代修谱,如何看待支系单飞的现象?

族谱与支谱、房谱的区别 现代修谱&#xff0c;修的是什么谱&#xff0c;你知道吗&#xff1f;其实现代修谱的种类有很多种&#xff0c;有支谱、房谱、族谱、宗谱、统谱、通谱等等&#xff0c;而这些在生活中都被我们简称为家谱。 不过在现代修谱里&#xff0c;宗谱、统谱、通谱…

极智编程 | 谈谈 C++ 中容器 map 和 unordered_map 的区别

欢迎关注我的公众号 [极智视界]&#xff0c;获取我的更多笔记分享 大家好&#xff0c;我是极智视界&#xff0c;本文来 谈谈 C 中 map 和 unordered_map 的区别。 map 和 unordered_map 都可以看做是一种 key-value 的映射关系&#xff0c;unordered_map 可以理解为 无序版的ma…

C语言 数组

C语言 数组一、一维数组1. 数组的创建方式程序清单1程序清单22. 计算数组的元素的个数3. 数组在内存中的存储方式二、二维数组1. 二维数组的创建方式2. 计算二维数组的行和列3. 二维数组在内存中的存储方式三、数组名的含义总结数组名的应用场景数组名作为函数参数一、一维数组…

22.11.16打卡 mysql学习笔记

马上要考试了, 越到考试越想玩, 烦躁烦躁烦躁, 没学多少, 争取明天把mysql基础篇学完 DCL介绍 2022年11月16日 14:54 DCL主要用来处理数据库有哪些用户可以访问, 每个用户具有什么样的权限 用户管理 2022年11月16日 15:20 所有用户的数据都存放在系统数据库mysql中的user表…

Python是什么?要如何学习?

Python 是荷兰人 Guido van Rossum &#xff08;吉多范罗苏姆&#xff0c;中国程序员称其为“龟叔”&#xff09;在 1990 年初开发的一种解释型编程语言。 Python 的诞生是极具戏曲性的&#xff0c;据 Guido 自述记载&#xff0c;Python 语言是在圣诞节期间为了打发无聊的时间而…