dp-力扣-按规则计算乘积

特判0;

为了深入了解这些生物群体的生态特征,你们进行了大量的实地观察和数据采集。数组 arrayA 记录了各个生物群体数量数据,其中 arrayA[i] 表示第 i 个生物群体的数量。请返回一个数组 arrayB,该数组为基于数组 arrayA 中的数据计算得出的结果,其中 arrayB[i] 表示将第 i 个生物群体的数量从总体中排除后的其他数量的乘积。

示例 1:

复制代码
输入:arrayA = [2, 4, 6, 8, 10]
输出:[1920, 960, 640, 480, 384]

提示:

  • 所有元素乘积之和不会溢出 32 位整数
  • arrayA.length <= 100000
cpp 复制代码
class Solution {
public:
    vector<int> statisticalResult(vector<int>& arrayA) {
        int len=arrayA.size();
         int sum=1;
         vector<int> v(len);
         int num=0; int id=0;
        for(int i=0;i<len;i++){
             if(arrayA[i]!=0)sum*=arrayA[i];
             else{
                num++;
                id=i;
             }
        }
        if(num>1) return v;
        if(num==1){
            v[id]=sum;
            return v;
        }
        for(int i=0;i<len;i++){
              v[i]=sum/arrayA[i];
        }
        return v;
    }
};
相关推荐
篮l球场10 分钟前
数组中的第K个最大元素
数据结构·算法·leetcode
月落归舟20 分钟前
排序算法---(三)
数据结构·算法·排序算法
njidf25 分钟前
C++中的观察者模式
开发语言·c++·算法
2301_8227828228 分钟前
C语言数组通关攻略!从一维到字符数组,零基础也能轻松掌握
c语言·算法·数组·编程基础·避坑技巧
zhugby34 分钟前
标号法原理
算法
努力学习的小廉1 小时前
我爱学算法之——动态规划(一)
算法·动态规划
篮l球场1 小时前
前 K 个高频元素
数据结构·算法·leetcode
编程一生1 小时前
面试问到的那些技术细节
面试·职场和发展
汉克老师1 小时前
GESP5级C++考试语法知识(十一、递归算法(一))
c++·算法·记忆化搜索·递归算法·递归优化
qq_148115372 小时前
C++网络编程(Boost.Asio)
开发语言·c++·算法