【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;
   
}

欢迎纠错与讨论哦

相关推荐
水饺编程4 分钟前
第4章,[标签 Win32] :SysMets3 程序讲解02,iVertPos
c语言·c++·windows·visual studio
波哥学开发7 分钟前
深入解析 BEV 图像色彩调整与伪彩色映射:从直方图统计到着色器实现
算法·图形学
西西弟16 分钟前
最短路径之Floyd算法(数据结构)
数据结构·算法
小O的算法实验室22 分钟前
2026年SEVC,直觉模糊不确定环境下求解绿色多物品固定费用五维运输问题的多目标进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
海海不瞌睡(捏捏王子)33 分钟前
Unity A*寻路算法
算法·unity
jaysee-sjc37 分钟前
【项目三】用GUI编程实现局域网群聊软件
java·开发语言·算法·安全·intellij-idea
code_whiter1 小时前
C\C++5(内存管理)
c语言·c++
HABuo1 小时前
【linux线程(二)】线程互斥、线程同步、条件变量详细剖析
linux·运维·服务器·c语言·c++·ubuntu·centos
DC...1 小时前
【力控】混合位置 / 力控制
算法·机器人·力控
Rabitebla1 小时前
归并排序(MergeSort)完全指南 —— 从原理到非递归实现
c语言·数据结构·c++·算法·排序算法