【C语言】每日一题(除自身以外数组的乘积)

添加链接描述,链接奉上

方法:

暴力循环:

暴力循换真的是差生法宝,简单好懂,就是不实用,大多数的题目都会超过时间限制(无奈)

思路:

1.写一个除自身的数组乘积函数

2.利用for循环遍历数组i作为循环变量,当遍历到i时,就求出除i以外的数组乘积

3.放入返回数组中

代码实现:

c 复制代码
static int arr[100000];
 int mul_self(int* nums, int numsSize,int i)
 //编写一个除自身的数组乘积函数
 {
    int mul=1;
    for(int j=0;j<numsSize;j++)
    {
        if(j!=i)
        mul*=nums[j];
    }
    return mul;
 }
int* productExceptSelf(int* nums, int numsSize, int* returnSize)
{
    *returnSize=numsSize;
    int n=0;
    for(int i=0;i<numsSize;i++)
    //循环遍历,求出每个除i外数组的乘积
    {
        arr[n++]=mul_self(nums,numsSize,i);
    }
    return arr;
}

但是此方法局限大,时间超出限制。

前缀积×后缀积(分组):

思路:

根据题目提示,利用前缀积×后缀积即可得到答案,那么问题就演化为求前缀积与后缀积

创建两个数组,一个用来存放前缀积,另一个存放后缀积。

最后循环,将两者相乘,得到除了nums[i]外的数组乘积

代码实现:

c 复制代码
static int ans[100000];

int* productExceptSelf(int* nums, int numsSize, int* returnSize)
{

    int lsum[numsSize];//创建数组
    int rsum[numsSize];
    lsum[0]=1;//将边界赋值为1
    rsum[numsSize-1]=1;
    for(int i = 1;i < numsSize; i++)//求前缀积
    {
        lsum[i]=lsum[i-1]*nums[i-1];
    }
    for(int i = numsSize-2;i >= 0;i--)//求后缀积
    {
        rsum[i]=rsum[i+1]*nums[i+1];
    }
    for(int i = 0;i<numsSize;i++)//求结果数组
    {
        ans[i]=lsum[i]*rsum[i];
    }
    *returnSize=numsSize;
    return ans;
   
}

欢迎纠错与讨论哦

相关推荐
lifallen2 分钟前
从Apache Doris 学习 HyperLogLog
java·大数据·数据仓库·算法·apache
智驱力人工智能27 分钟前
使用手机检测的智能视觉分析技术与应用 加油站使用手机 玩手机检测
深度学习·算法·目标检测·智能手机·视觉检测·边缘计算
姚瑞南1 小时前
【AI 风向标】四种深度学习算法(CNN、RNN、GAN、RL)的通俗解释
人工智能·深度学习·算法
补三补四1 小时前
SMOTE 算法详解:解决不平衡数据问题的有效工具
人工智能·算法
RTC老炮2 小时前
webrtc弱网-RobustThroughputEstimator源码分析与算法原理
网络·算法·webrtc
努力努力再努力wz2 小时前
【C++进阶系列】:万字详解智能指针(附模拟实现的源码)
java·linux·c语言·开发语言·数据结构·c++·python
凤年徐2 小时前
【C++】string的模拟实现
c语言·开发语言·c++
听风吹等浪起2 小时前
分类算法-逻辑回归
人工智能·算法·机器学习
敲代码的嘎仔2 小时前
JavaWeb零基础学习Day2——JS & Vue
java·开发语言·前端·javascript·数据结构·学习·算法
yacolex2 小时前
3.3_数据结构和算法复习-栈
数据结构·算法