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

【力扣】238.除自身以外数组的乘积

AC截图

题目

思路

前缀积

前缀积指的是对于一个给定的数组arr,构建一个新的数组prefixProduct,其中prefixProduct[i]表示原数组从第一个元素到第i个元素(包括i)的所有元素的乘积。形式化来说:

  • prefixProduct[0] = arr[0]
  • 对于i > 0prefixProduct[i] = arr[0] * arr[1] * ... * arr[i]

通过这种方式,你可以快速获取数组任意位置之前(包括当前位置)所有元素的乘积。

后缀积

类似地,后缀积是指对于给定数组arr,构建另一个数组suffixProduct,其中suffixProduct[i]表示原数组从最后一个元素到第i个元素(包括i)的所有元素的乘积。形式化来说:

  • suffixProduct[n-1] = arr[n-1],其中n是数组的长度。
  • 对于i < n-1suffixProduct[i] = arr[n-1] * arr[n-2] * ... * arr[i]

这样就可以迅速查询数组中任意位置之后(包括当前位置)所有元素的乘积。

本题可以根据题目要求,稍微修改一下,让前缀积和后缀积并不包含元素本身。

代码

class Solution {
public:vector<int> productExceptSelf(vector<int>& nums) {int len=nums.size();vector<int> res(len,1);int pre=1;int suf=1;for(int i=0;i<len;i++){res[i] *= pre;pre *= nums[i];}for(int j=len-1;j>=0;j--){res[j] *= suf;suf *= nums[j];}return res;}
};

http://www.lryc.cn/news/531622.html

相关文章:

  • Nacos 的介绍和使用
  • DeepSeek最新图像模型Janus-Pro论文阅读
  • 【仿12306项目】基于SpringCloud,使用Sentinal对抢票业务进行限流
  • 【赵渝强老师】Spark RDD的依赖关系和任务阶段
  • 【B站保姆级视频教程:Jetson配置YOLOv11环境(六)PyTorchTorchvision安装】
  • Verilog语言学习总结
  • 【阅读笔记】LED显示屏非均匀度校正
  • 【Java异步编程】CompletableFuture基础(1):创建不同线程的子任务、子任务链式调用与异常处理
  • ESXI虚拟机中部署docker会降低服务器性能
  • ASP.NET Core与配置系统的集成
  • 中间件的概念及基本使用
  • SpringBoot 整合 Mybatis:注解版
  • 18.[前端开发]Day18-王者荣耀项目实战(一)
  • Kafka 使用说明(kafka官方文档中文)
  • 基于多智能体强化学习的医疗AI中RAG系统程序架构优化研究
  • Airflow:深入理解Apache Airflow Task
  • multisim入门学习设计电路
  • 【算法精练】二分查找算法总结
  • 从零开始实现一个双向循环链表:C语言实战
  • MYSQL面试题总结(题目来源JavaGuide)
  • visual studio安装
  • JVM执行引擎
  • C# 9.0记录类型:解锁开发效率的魔法密码
  • 搭建自己的专属AI——使用Ollama+AnythingLLM+Python实现DeepSeek本地部署
  • 『 C++ 』中理解回调类型在 C++ 中的使用方式。
  • git多人协作
  • CTFSHOW-WEB入门-命令执行71-77
  • 浅谈《图解HTTP》
  • LLMs瞬间获得视觉与听觉感知,无需专门训练:Meta的创新——在图像、音频和视频任务上实现最优性能。
  • 自研有限元软件与ANSYS精度对比-Bar3D2Node三维杆单元模型-央视大裤衩实例