【算法】前缀和——除自身以外数组的乘积

2024-05-24 07:28

本文主要是介绍【算法】前缀和——除自身以外数组的乘积,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本节博客是用前缀和算法求解“除自身以外数组的乘积”,有需要借鉴即可。

目录

  • 1.题目
  • 2.前缀和算法
  • 3.变量求解
  • 4.总结

1.题目

题目链接:LINK
在这里插入图片描述

2.前缀和算法

  • 1.创建两个数组
    • 第一个数组第i位置表示原数组[0,i-1]之积
    • 第二个数组第i位置表示原数组[i+1,n-1]之积
  • 2.进行求解结果

图解如下:
在这里插入图片描述
在这里插入图片描述

参考代码如下:

class Solution {
public:vector<int> productExceptSelf(vector<int>& nums) {//预处理前缀和数组int n = nums.size();vector<long long> f(n);vector<long long> g(n);f[0] = 1;g[n-1] = 1;for(size_t 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];}//求结果vector<int> ret(n);for(size_t i = 0; i < n; i++){ret[i] = f[i] * g[i];}return ret;}
};

3.变量求解

下面我们来挑战一下这道题的进阶版本:要求我们空间复杂度O(1)
在这里插入图片描述
显然,前缀和算法时间复杂度是O(N),不满足题目要求,因而我们应该用变量求解。

class Solution {
public:vector<int> productExceptSelf(vector<int>& nums) {//要求空间复杂度:O(1)int n = nums.size();int f = 1;//充当前缀积变量int g = 1;//充当后缀积变量vector<int> ret(n,1);for(int i = 0; i<n; i++){ret[i]*= f;f *= nums[i];}for(int i = n - 1; i >= 0 ;i--){ret[i]*= g;g*=nums[i];}return ret;}
};

当然,两次循环也可以合并一下,就成下面这个代码了:

class Solution {
public:vector<int> productExceptSelf(vector<int>& nums) {//要求空间复杂度:O(1)int n = nums.size();int f = 1;//充当前缀积变量int g = 1;//充当后缀积变量vector<int> ret(n,1);for(int i = 0; i<n; i++){ret[i]*= f;ret[n-1-i]*= g;f *= nums[i];g *= nums[n-1-i];}return ret;}
};

注:两个代码在效率上并没有提升。后者比前者虽然看着少了一次循环,但是我感觉效率是一样的,该怎么算还是怎么算,只不过是两种不同的写法而已!

4.总结

这个题目是一个简单运用前缀和的简单题目。

进阶方面来看:这个题用前缀和多开空间虽然可以,不过有点多余,因为我们记住那么多数没用,下一次要用的数是确定的,所以不用记那么多,记住下一次要用的数字就行。


EOF

这篇关于【算法】前缀和——除自身以外数组的乘积的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

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

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

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

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

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

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

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

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

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

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ