6个数组成乘积最大,

  6个数组成乘积最大,

  NC106三个数的最大乘积

  描述一个长度为的无序数组,包含正数,负数和0。请从中找出3个数字,以最大化产品并退回此产品。

  所需的时间复杂度:空间复杂度:

  数据范围:

  示例1输入:

  [3,4,1,2]返回值:

  24.分类解决方案的想法:

  先对数组进行排序,判断负数k的个数是否大于等于2k且小于2,最大值为最后三个正数的乘积;否则,最大的三个数可能是最后三个正数的乘积,也可能是最小的两个负数和最大的正数的乘积。注意:

  其实我们不需要neg_count,可以直接计算乘积,不管最小的2个数是不是负数。

  代码如下:

  #包含位/标准数据。h

  使用命名空间std

  long long solve(int *A,int ALen)

  {

  std:sort(A,A ALen);

  int neg _ count=0;

  while (A[neg_count] 0)

  {

  neg _计数;

  }

  if (neg_count 2)

  {

  返回A[阿伦-1]* A[阿伦-2]* A[阿伦-3];

  }

  long long ans=A[0];

  ans *=A[1];

  long long b=A[阿伦-2]* A[阿伦-3];

  返回A[ALen - 1] * std:max(ans,b);

  }未分类的解决方案想法:

  其实我们只需要找到最小的2个数和最大的3个数,然后根据上面的分析直接比较两种情况的乘积。

  代码省略~ ~

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

相关文章阅读

  • office2010激活密钥大全 怎么永久激活office2010
  • project2010产品密钥免费_project2010激活密钥永久激活码
  • c语言调用退出函数 c语言退出整个程序怎么写
  • c语言中怎么给函数初始化 c语言的初始化语句
  • c语言编写函数计算平均值 c语言求平均函数
  • chatgpt是什么?为什么这么火?
  • ChatGPT为什么注册不了?OpenAI ChatGPT的账号哪里可以注册?
  • OpenAI ChatGPT怎么注册账号?ChatGPT账号注册教程
  • chatgpt什么意思,什么是ChatGPT ?
  • CAD中怎么复制图形标注尺寸不变,CAD中怎么复制图形线性不变
  • cad中怎么创建并使用脚本文件,cad怎么运行脚本
  • cad中快速计算器的功能,cad怎么快速计算
  • cad中快速修改单位的方法有哪些,cad中快速修改单位的方法是
  • cad中心点画椭圆怎么做,cad轴测图怎么画椭圆
  • CAD中常用的快捷键,cad各种快捷键的用法
  • 留言与评论(共有 条评论)
       
    验证码: