算法竞赛入门经典 暴力求解法 7.1简单枚举 最大乘积

摘要:
如果此最大乘积不是正数,则应输出-1。样本输入:324-3525-12-1样本输出:830分析:连续子序列中有两个元素:起点和终点,因此您只需枚举起点和终点。由于每个元素的绝对值不超过10,并且总共不超过18个元素,因此最大可能乘积不会超过10^18,这可以在long long中保存。

问题描述:输入n个元素组成的序列S,你需要找出一个乘积最大的连续子序列。如果这个最大的乘积不是正数,应输出-1(表示无解)。-1<=n<=18,-10<=Si<=10。

样例输入:

3

2 4 -3

2 5 -1  2 -1

样例输出:

8

30

分析:连续子序列有两个要素:起点和终点,因此只需枚举起点和终点即可。由于每个元素的绝对值不超过10,一共又不超过18个元素,最大可能的乘积不会超过10^18,可以用long long存下。

下面贴上实现代码(可以实现多组样例输入)

<span style="font-size:12px;">#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<algorithm>
#include<string.h>
using namespace std;
typedef long long ll;
const ll N=20;
ll S[N];
ll n;
ll comp(const void *a,const void *b)
{
    return *(int*)b-*(int*)a;
}
int main()
{
    while(scanf("%I64d",&n)==1)
    {
       for(ll i=0;i<n;i++)
       {
           scanf("%I64d",&S[i]);
       }
       ll dp=0,temp=1;
       for(ll i=0;i<n;i++)
       {
           temp=S[i];
           if(temp>dp)
           {
               dp=temp;
           }
           for(ll j=i+1;j<n;j++)
           {
              temp*=S[j];
              if(temp>dp)
              {
                  dp=temp;
              }
           }
       }
       if(dp>0)
        printf("%I64d
",dp);
       else
        printf("-1
");
    }
}</span>

版权声明:本文为博主原创文章,未经博主允许不得转载。

免责声明:文章转载自《算法竞赛入门经典 暴力求解法 7.1简单枚举 最大乘积》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇V8 初次接触(Qt5) 1+1=2 博客频道 CSDN.NETJ2EE的13个规范之(二) JDBC 及其使用下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

随便看看

联想笔记本如何安装固态硬盘-联想G50-80如何安装固态硬盘(全流程+装系统)

我们以联想G50-80为例,介绍如何添加固态。为确保电脑在更换过程中不会意外启动,请务必取出电池!确认安装到位后,安装四个螺钉(红色圆圈处)。此时,可能会弹出一些BIOS检查失败消息。...

.NET Core项目部署时自定义端口号

我会在有时间的时候总结Linux系统的部署。NETCore项目只使用这种方法。5.IIS部署项目。指定端口号环境:Windows。NET开发人员应该熟悉IIS吗。当我们使用IIS部署Core项目时,它与之前的Framework项目的部署类似。您可以自定义端口号。...

unity, 设置帧率上限

使用unity制作演示,并移除所有昂贵的特效。在真正的机器上运行仍然会导致问题。最大显示帧速率为30。默认情况下,IOS设备上统一的原始帧速率限制为30。应用targetFrameRate=60;更改为最大值60。请注意,此设置对编辑器没有影响。...

Centos-修改文件访问和修改时间-touch

触摸如果文件存在,请更改文件的访问时间和修改时间。如果不存在,请创建一个空的文件相关选项。a将文件访问时间更改为当前系统时间。m将文件修改时间更改为当前系统时间。c如果文件不存在,请不要创建它。d不提示。d指定日期和时间。格式为Y-m-dH:m:S-r递归修改目录下的所有文件和内容...

android动态申请权限

申请权限对于安卓开发很重要,从Android6.0开始,Android系统提供动态申请权限的机制,APP在使用危险权限时,需要用户的授权才可进一步操作。...