【LeetCode刷题】前缀和解决问题:742.寻找数组的中心下标、238.除自身以外数组的乘积

本文主要是介绍【LeetCode刷题】前缀和解决问题:742.寻找数组的中心下标、238.除自身以外数组的乘积,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【LeetCode刷题】Day 15

  • 题目1:742.寻找数组的中心下标
    • 思路分析:
    • 思路1:前缀和思想
  • 题目2:238.除自身以外数组的乘积
    • 思路分析
    • 思路1:前缀和思想

在这里插入图片描述

题目1:742.寻找数组的中心下标

在这里插入图片描述

思路分析:

其实题干说的很明白了,就是在表述,某个位置的前半部分数组和与后半部分数组和的结果相同,就是中心下标。
这里明显就是前缀和来求解。

思路1:前缀和思想

前半部分的和与后半部分的和分别用:前缀和f数组,后缀和g数组来表示。
前缀和f:f[i]表示:从数组开始位置到下标为i前一个位置[0,i-1]的总和
后缀和g:g[i]表示:数组最后一个位置到下标为i位置的后一个位置[i+1,n-1]的总和

f,g数组的递推公式如下:

//前缀和数组f的递推公式:
f[i] = f[i-1] + nums[i-1];
//后缀和数组g的递推公式:
g[i] = g[i+1] + nums[i+1];

注意细节问题:

  • 初始化:前缀和f: 当i=0时,也就是0的前面的和,我们需要设置为0,即f[0]=0。同理,后缀和g: i=n-1时,表示数组中最后一个元素后的和,也同样设置为0,即g[n-1]=0
  • 越界问题:f数组:i从1开始建立,这样才能保证i-1不越界。g数组:i从n-2开始才不会越界。

代码实现:

class Solution {
public:int pivotIndex(vector<int>& nums) {int n=nums.size();vector<int> f(n),g(n); //此处已经把f[0]和g[n-1]默认初始化为0了。//1.预处理前缀和数组f,后缀和数组g。for(int i=1;i<n;i++) f[i]=f[i-1]+nums[i-1];for(int i=n-2;i>=0;i--)g[i]=g[i+1]+nums[i+1];//2.使用前缀和数组和后缀和数组。for(int i=0;i<n;i++)if(f[i]==g[i]) return i;return -1;}
};

LeetCode链接:742.寻找数组的中心下标


题目2:238.除自身以外数组的乘积

在这里插入图片描述

思路分析

思路其实题目已经说的很明显了,唯一要注意的是初始化化,这里是乘法,所以初始值为1。

思路1:前缀和思想

所得的最后数组地每一个位置元素是由,该元素前面区间的乘积来和后面区间的乘积相乘的出来的。所以前缀和思想很合适。
代码实现:

class Solution {
public:vector<int> productExceptSelf(vector<int>& nums) {int n=nums.size();vector<int> ret(n);vector<int> f(n,1),g(n,1);  //1.预处理前缀和后缀数组for(int i=1;i<n;i++)f[i]=f[i-1]*nums[i-1];for(int i=n-2;i>=0;i--)g[i]=g[i+1]*nums[i+1];//2.使用前缀和后缀数组for(int i=0;i<n;i++)ret[i]=f[i]*g[i];return ret;}   
};

LeetCode链接:238.除自身以外数组的乘积


✨享受平静,也努力向上!
平静是幸福,努力学习也是幸福! ~天天开心🎈

请添加图片描述

这篇关于【LeetCode刷题】前缀和解决问题:742.寻找数组的中心下标、238.除自身以外数组的乘积的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1026076

相关文章

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

springboot加载不到nacos配置中心的配置问题处理

《springboot加载不到nacos配置中心的配置问题处理》:本文主要介绍springboot加载不到nacos配置中心的配置问题处理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录springboot加载不到nacos配置中心的配置两种可能Spring Boot 版本Nacos

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

SpringCloud使用Nacos 配置中心实现配置自动刷新功能使用

《SpringCloud使用Nacos配置中心实现配置自动刷新功能使用》SpringCloud项目中使用Nacos作为配置中心可以方便开发及运维人员随时查看配置信息,及配置共享,并且Nacos支持配... 目录前言一、Nacos中集中配置方式?二、使用步骤1.使用$Value 注解2.使用@Configur

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

正则表达式r前缀使用指南及如何避免常见错误

《正则表达式r前缀使用指南及如何避免常见错误》正则表达式是处理字符串的强大工具,但它常常伴随着转义字符的复杂性,本文将简洁地讲解r的作用、基本原理,以及如何在实际代码中避免常见错误,感兴趣的朋友一... 目录1. 字符串的双重翻译困境2. 为什么需要 r?3. 常见错误和正确用法4. Unicode 转换的

Java如何根据文件名前缀自动分组图片文件

《Java如何根据文件名前缀自动分组图片文件》一大堆文件(比如图片)堆在一个目录下,它们的命名规则遵循一定的格式,混在一起很难管理,所以本文小编就和大家介绍一下如何使用Java根据文件名前缀自动分组图... 目录需求背景分析思路实现代码输出结果知识扩展需求一大堆文件(比如图片)堆在一个目录下,它们的命名规

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的