Rust 力扣 - 238. 除自身以外数组的乘积

文章目录

题目描述

题解思路

这题主要有个关键点,就是元素能取0,然后我们分类讨论元素为0的数量

  • 如果数组中存在至少两个元素为0,则每个元素的除自身以外的乘积为0
  • 如果数组中仅存在一个0,则为0的这个元素对应的除自身以外的乘积为数组中所有非0元素的乘积,其它元素的除自身以外的乘积为0
  • 如果数组中不存在0,则每个元素的除自身以外的乘积为所有元素的乘积除以自身元素

题解代码

rust 复制代码
impl Solution {
    pub fn product_except_self(nums: Vec<i32>) -> Vec<i32> {
        let mut sum = 1;

        let mut zero_count = 0;

        for num in &nums {
            if *num != 0 {
                sum *= num;
            } else {
                zero_count += 1;            
            }
        }

        let mut ans = vec![0; nums.len()];

        if zero_count > 1 {
            return ans;
        }

        if zero_count == 1 {
            for i in 0..nums.len() {
                if nums[i] == 0 {
                    ans[i] = sum;
                    return ans;
                }
            }
        }

        for i in 0..nums.len() {
            ans[i] = sum / nums[i];
        }

        ans
    }
}

题解链接

https://leetcode.cn/problems/product-of-array-except-self/

相关推荐
五条凪40 分钟前
从零开始的LeetCode刷题日记:70. 爬楼梯
数据结构·算法·leetcode·职场和发展·1024程序员节
weixin_404679311 小时前
pdf转图片
linux·运维·开发语言·python·pdf
小丁爱养花1 小时前
算法专题:栈
数据结构·算法·leetcode
CSXB991 小时前
三十一、Python基础语法(多态)
开发语言·python·功能测试·测试工具
蝶恋舞者1 小时前
QT下载安装
开发语言·qt
程序媛96881 小时前
计算机毕业设计——ssm基于JAVA的求职招聘网站的设计与实现演示录像 2021
java·开发语言·毕业设计·求职招聘·课程设计
azhou的代码园1 小时前
基于SpringBoot+微信小程序+协同过滤算法+二维码订单位置跟踪的农产品销售平台-新
spring boot·算法·微信小程序
富能量爆棚2 小时前
Scala的包及其导入
开发语言·后端·scala
cuisidong19972 小时前
5G无线帧基本架构
网络·算法·5g
大福是小强2 小时前
004-Kotlin界面开发快速入水之TicTacToe
开发语言·kotlin·界面开发·gui·教程·桌面应用·快速入水