栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

三个数的最大乘积(LeetCode 628)C语言

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

三个数的最大乘积(LeetCode 628)C语言

 题目来源

628. 三个数的最大乘积 - 力扣(LeetCode) (leetcode-cn.com)https://leetcode-cn.com/problems/maximum-product-of-three-numbers/

代码实现
#include

int* sort(int a[], int n)
{
    int i, j, temp;
    for (i = 0; i < n - 1; i++)                   //比较n-1次(第一次循环表示趟数)
    {
        for (j = 0; j < n - i - 1; j++)              // 最后一次比较a[n-i-1]与a[n-i-2]   (第二次循环表示比较次数 )
        {
            if (a[j] < a[j + 1])
            {
                temp = a[j + 1];
                a[j + 1] = a[j];
                a[j] = temp;
            }
        }
    }
    return a;
}

int sum = 1;
int i = 0;
int FindMaxi(int* nums, int numsSize)
{
    for (i = 0; i < numsSize; i++)
    {
        if (nums[i] > 0 && nums[i + 1] < 0) return i;
    }
}
int maximumProduct(int* nums, int numsSize)
{
    if (numsSize < 3)  return 0;
    if (numsSize == 3)
    {
        for (int i = 0; i < numsSize; i++) sum *= nums[i];
        return sum;
    }
    else
    {
        sort(nums, numsSize);
        int ret1 = nums[0] * nums[1] * nums[2];//nums全正全负情况
        int ret2 = nums[0] * nums[numsSize-1] * nums[numsSize-2];
        return ret1>ret2 ? ret1:ret2;

    }
}
int main()
{
	int a[3] = { -1,-2,-3};
	printf("%dn",maximumProduct(a, 3));
	return 0;
}

 在自己电脑上运行是对的

兄弟们帮忙看下,哪里有错,为什么力扣那通不过!!!!! 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/857865.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号