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

leetcode Top100 238. 除自身以外数组的乘积|数组系列

题目链接:238. 除自身以外数组的乘积 - 力扣(LeetCode)

238. 除自身以外数组的乘积|数组系列

给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。

题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在  32 位 整数范围内。

请 不要使用除法,且在 O(n) 时间复杂度内完成此题。

示例 1: 输入: nums = [1,2,3,4]          输出: [24,12,8,6]

示例 2: 输入: nums = [-1,1,0,-3,3]         输出: [0,0,9,0,0]

解题思路:

题目中给出前缀和后缀的乘积 那该题十有八九就和前缀后缀有关 

题意给出的输出[24,12,8,6] 可以拆分为 [1*2*3*4, 1*3*4 ,1*2*4, 1*2*3]

再整理一下 [2*3*4, 1*3*4 ,1*2*4, 1*2*3] 可以看出是除去本身数字来实现 

所以可以先计算前缀乘积 [1, 1*1, 1*1*2, 1*1*2*3] = [1,1,2,6]

后缀乘积[2*3*4,3*4,4,1] = [24,12,4,1]

那么 前后缀乘积相乘就是所求输出 [24,12,8,6]

Java代码:

class soul{public int[] productExceptSelf(int[] nums){if(nums == null || nums.length == 0){//剪枝return null;}int n = nums.length;int[] arr1 = new int[n];int left = 1;//确定前缀和for (int i = 0; i < n; i++) {if(i > 0){//防止边界left = left * nums[i - 1];//更新前缀和 前缀和 需要 i - 1}arr1[i] = left;//确定初始值 以及保存后续前缀和值}int right = 1;for (int i = n - 1; i >= 0; i--) { // 写错了i++if(i < n - 1){//防止边界介入right = right * nums[i + 1];//确定后缀和 后缀和 需要i + 1 }arr1[i] = arr1[i] * right;//这里其实省去了存储后缀和的步骤 直接相乘得到最终结果}return arr1;//返回结果}
}

http://www.xdnf.cn/news/12743.html

相关文章:

  • 批量修改文件夹名 修改文件夹名
  • Spring Cloud Alibaba Seata安装+微服务实战
  • 【第九篇】 SpringBoot测试补充篇
  • Zustand 第二章(状态处理)
  • 【设计模式】2.策略模式
  • 【网站建设】不同类型网站如何选择服务器?建站项目实战总结
  • AI智能体|扣子(Coze)搭建【公众号对标文章采集拆解】工作流
  • DeepSeek11-Ollama + Open WebUI 搭建本地 RAG 知识库全流程指南
  • windows10下搭建nfs服务器
  • 【分布式】分布式ID介绍和实现方案总结
  • 力扣算法题1
  • Vue部署到Nginx上及问题解决
  • 深入理解 React Hooks
  • 通过css实现正方体效果
  • 【免费数据】2005-2019年我国272个地级市的旅游竞争力多指标数据(33个指标)
  • C++11 右值引用
  • Pandas-如何正确将两张数据表进行合并
  • 自定义protoc-gen-go生成Go结构体,统一字段命名与JSON标签风格
  • 【Zephyr 系列 15】构建企业级 BLE 模块通用框架:驱动 + 事件 + 状态机 + 低功耗全栈设计
  • github开源协议选择
  • iview-admin静态资源js按需加载配置
  • STM标准库-TIM旋转编码器
  • JAVASCRIPT 前端数据库-V6--仙盟数据库架构-—-—仙盟创梦IDE
  • 深入浅出 Arrays.sort(DualPivotQuicksort):如何结合快排、归并、堆排序和插入排序
  • 2025年夏第九届河北工业大学程序设计校赛
  • Linux 上的 Tomcat 端口占用排查
  • 2025-06-08 思考-人被基因和社会关系双重制约
  • Psychopy音频的使用
  • 实验四:图像灰度处理
  • 自动化立体仓库堆垛机控制系统STEP7 OB1功能块