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

银锭网那个网站做的 好上海公司排名

银锭网那个网站做的 好,上海公司排名,常州市城市建设局网站,网站开发公司会计处理238. 除自身以外数组的乘积 给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法&a…

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]

提示:

  • 2 <= nums.length <= 105
  • -30 <= nums[i] <= 30
  • 输入 保证 数组 answer[i] 在  32 位 整数范围内

思路分析

如果用除法的话,可以先算所有数的乘积,然后每个位置除以自己。但题目中不允许使用除法,我想到的另一个方法是前缀和后缀的乘积。比如,对于每个元素 i 来说,左边所有元素的乘积乘上右边所有元素的乘积,就是结果。那这样,先从左到右计算每个元素的左边乘积,存到一个数组里,然后从右到左计算右边乘积,再乘到对应的左边乘积上,得到最终结果。

具体步骤

  1. 初始化一个answer数组,长度和nums一样。
  2. 计算左边的乘积,从左到右遍历。首先answer[0] = 1,然后后面的每个元素 i ,answer[i] = answer[i-1] * nums[i-1]。这样answer数组此时保存的是每个元素的左边乘积。
  3. 然后计算右边的乘积,用一个变量rightProduct来保存右边的累积,初始化为1。
  4. 从右往左遍历,每次将answer[i]乘以rightProduct,然后更新rightProduct *= nums[i]。这样,在遍历过程中answer[i] = left[i] * rightProduct。其中rightProduct是右边所有元素的乘积。

这样的话,整个过程是两次遍历

        首先初始化answer数组。第一个循环,从左到右填充左边乘积。然后第二个循环,从右到左,用rightProduct变量来乘。具体步骤:

        初始化answer数组,长度为nums.length。answer[0] = 1。然后对于i从1到nums.length-1,answer[i] = answer[i-1] * nums[i-1]。

        然后初始化rightProduct为1。然后从i=nums.length-1到0,循环。每次将answer[i]乘以rightProduct,然后rightProduct *= nums[i]。

程序代码

class Solution {public int[] productExceptSelf(int[] nums) {int n = nums.length;int[] answer = new int[n];answer[0] = 1;// 计算每个元素的左边乘积for(int i = 1; i < n; i++){answer[i] = answer[i - 1] * nums[i - 1];}// 计算右边乘积并乘以左边乘积int rightProduct = 1;for(int i = n - 1; i >= 0; i--){answer[i] *= rightProduct;rightProduct *= nums[i];}return answer;}
}
  1. 步骤分解

    • 前缀乘积计算:从左到右遍历数组,answer[i]存储nums[i]左边所有元素的乘积。

    • 后缀乘积整合:从右到左遍历数组,使用变量rightProduct动态维护当前元素右边的乘积,并直接将其乘到answer[i]上。

  2. 复杂度:两次遍历,时间复杂度O(n);结果数组外额外空间O(1),满足题目要求。

http://www.dtcms.com/wzjs/440422.html

相关文章:

  • 浙江王氏生态建设网站西安关键词推广
  • 大学生做简历的网站济南网站优化公司哪家好
  • 网站建设策划方案书网站建设与维护
  • 长沙专门做网站建设的公司深圳优化seo排名
  • 少儿编程加盟官网优化关键词有哪些方法
  • SEO网站布局优化百度seo关键词排名技术
  • 泰安市人才市场灰色关键词排名优化
  • 怎么做提货网站网络营销都有哪些形式
  • 做网站具体流程郑州网站推广排名公司
  • lovestory wordpress德阳seo
  • 北京代做网站谷歌seo排名公司
  • 广州做网站系统sem竞价培训班
  • 大型门户网站设计公司百度首页官网
  • 网站系统介绍宁波seo自然优化技术
  • 软件工程项目开发的步骤站长工具的使用seo综合查询排名
  • 徐州建网站国内搜索引擎
  • 阿里虚拟机建设网站国际新闻最新消息2022
  • 广州建网站的公司青岛官网seo公司
  • java开源代码网站南阳seo优化
  • 沈阳个人网站建设b站刺激战场视频
  • 西宁网站制作多少钱利尔化学股票
  • 网站蜘蛛怎么看seo咨询邵阳
  • 推荐做pc端网站百度会员登录入口
  • 做侵权网站用哪里的服务器网站如何推广
  • 做网站的细节软文范例大全100字
  • iis6 建设网站浏览网址大全123
  • 网站商城怎么做的seo中文全称是什么
  • 曲靖做网站建设的公司关键词优化简易
  • 个人网站模板html下载靠网络营销火起来的企业
  • 网站充值如何做post的长尾关键词搜索网站