力扣刷题Days30-238. 除自身以外数组的乘积(js)

2024-04-01 23:12

本文主要是介绍力扣刷题Days30-238. 除自身以外数组的乘积(js),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1,题目

2,代码

2.1左右乘积列表

2.2优化-空间复杂度常量化

算法实现:

3,学习与总结

3.1记录我的思考过程

3.2本题特点


1,题目

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

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

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

2,代码

2.1左右乘积列表

维护给定索引处的数字相对应的前缀和后缀;重点在于理解两个列表的初始化过程;

前缀:给定索引左侧所有数字的乘积;

后缀:给定索引右侧所有数字的乘积;

小tips:乘积 利用‘1’;

/*** @param {number[]} nums* @return {number[]}*/
var productExceptSelf = function(nums) {const n = nums.length;let ltable = new Array(n).fill(1);let rtable = new Array(n).fill(1);let ans = new Array(n).fill(0); for(let i = 1;i < n;i++){ltable[i] = ltable[i-1]*nums[i-1];}for(let i = n-2; i >= 0;i--){rtable[i] = rtable[i+1]*nums[i+1];}for(let i = 0;i < n;i++){ans[i] = ltable[i]*rtable[i];}return ans;};

2.2优化-空间复杂度常量化

由于输出数组不算在空间复杂度内,那么我们可以将 L 或 R 数组用输出数组来计算。先把输出数组当作 L 数组来计算,然后再动态构造 R 数组得到结果。

/*** @param {number[]} nums* @return {number[]}*/
var productExceptSelf = function(nums) {const n = nums.length;let ans = new Array(n).fill(1);for(let i = 1;i < n;i++){ans[i] = ans[i-1]*nums[i-1];}// R索引右侧所有数字的乘积let R = 1;for(let i = n-1; i >= 0;i--){ans[i] = ans[i] * R;R *= nums[i];} return ans;};
算法实现:
  1. 初始化 ans数组,answer[i] 先代表的是 i 左侧所有数字的乘积。
  2. 用一个遍历来跟踪右边元素的乘积。并更新数组answer[i]=answer[i]∗R。

说明:

R 更新为 R=R∗nums[i]

变量 R表示的就是索引右侧数字的乘积。

3,学习与总结

3.1记录我的思考过程

(1)积累一下对数组中0个数的统计

    const str = nums.join('');const n = (str.split('0')).length-1;

(2)我的思路

算出数组中所有数字的乘积,除以相对应索引值;

首先,判断0的个数numsOfzero

numsOfzero >= 2

numsOfzero === 1

numsOfzero === 0

问题在于numsOfzero 等于1或者0的情况需要单独处理,整体代码的实现相对繁琐;

3.2本题特点

要学习处理的方法;

了解处理思路后,可以自己实现代码逻辑,即主要在于解题思路上;


勉励自己:贵在坚持!

这篇关于力扣刷题Days30-238. 除自身以外数组的乘积(js)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

JS 实现复制到剪贴板的几种方式小结

《JS实现复制到剪贴板的几种方式小结》本文主要介绍了JS实现复制到剪贴板的几种方式小结,包括ClipboardAPI和document.execCommand这两种方法,具有一定的参考价值,感兴趣的... 目录一、Clipboard API相关属性方法二、document.execCommand优点:缺点:

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom