力扣刷题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

相关文章

JS常用组件收集

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

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

C 语言基础之数组

文章目录 什么是数组数组变量的声明多维数组 什么是数组 数组,顾名思义,就是一组数。 假如班上有 30 个同学,让你编程统计每个人的分数,求最高分、最低分、平均分等。如果不知道数组,你只能这样写代码: int ZhangSan_score = 95;int LiSi_score = 90;......int LiuDong_score = 100;int Zhou

使用JS/Jquery获得父窗口的几个方法(笔记)

<pre name="code" class="javascript">取父窗口的元素方法:$(selector, window.parent.document);那么你取父窗口的父窗口的元素就可以用:$(selector, window.parent.parent.document);如题: $(selector, window.top.document);//获得顶级窗口里面的元素 $(

js异步提交form表单的解决方案

1.定义异步提交表单的方法 (通用方法) /*** 异步提交form表单* @param options {form:form表单元素,success:执行成功后处理函数}* <span style="color:#ff0000;"><strong>@注意 后台接收参数要解码否则中文会导致乱码 如:URLDecoder.decode(param,"UTF-8")</strong></span>