牛客网-小美的加法(C++)

链接:登录---专业IT笔试面试备考平台_牛客网

来源:牛客网

题目描述

小美有一个长度为 n 的数组,她想将这个数组进行求和,即 sum=a1+a2+...+an。

小美可以使用一次魔法(也可以不使用),将其中一个加号变成乘号,使得 sum 最大。

求出最大的 sum 。

输入描述:

复制代码
第一行输入一个整数 n 。
第二行输入 n 个整数表示数组 a 。
1≤n≤10⁵
1≤ai≤10⁹

输出描述:

输出一个整数表示答案。

示例1

输入

复制代码
6
1 1 4 5 1 4

输出

复制代码
27

代码:

cpp 复制代码
#include <stdio.h>
#include <math.h>
#include <iostream>
using namespace std;
const int N=1e5+5;
int main(){
    long long n,a[N],MAX=0,sum=0;
    cin>>n;getchar();
     long long u=0,cn=0;
    for(long long i=1;i<=n;++i){
        cin>>a[i];
        sum+=a[i];
}   
    if(n==1){
        cout<<a[1]<<endl;
    }
    else{
        for(int i=1;i<n;++i){
        	if(a[i]+a[i+1]<a[i]*a[i+1]){
        if(a[i]*a[i+1]>MAX){
            MAX=max(MAX,a[i]*a[i+1]);
            cn=a[i]+a[i+1];
        }
    }
        }
        if(MAX==0) printf("%lld",sum);
    else  cout<<sum-cn+MAX<<endl;
}
    return 0;
}
相关推荐
谢景行^顾24 分钟前
数据结构知识掌握
linux·数据结构·算法
ShineWinsu1 小时前
对于数据结构:堆的超详细保姆级解析——下(堆排序以及TOP-K问题)
c语言·数据结构·c++·算法·面试·二叉树·
DuHz1 小时前
基于时频域霍夫变换的汽车雷达互干扰抑制——论文阅读
论文阅读·算法·汽车·毫米波雷达
hetao17338372 小时前
ZYZ28-NOIP模拟赛-Round4 hetao1733837的record
c++·算法
Nebula_g2 小时前
C语言应用实例:解方程(二分查找)
c语言·开发语言·学习·算法·二分查找·基础
少许极端3 小时前
算法奇妙屋(十)-队列+宽搜(BFS)
java·数据结构·算法·bfs·宽度优先·队列
想唱rap4 小时前
Linux开发工具(4)
linux·运维·服务器·开发语言·算法
前端炒粉5 小时前
21.搜索二维矩阵 II
前端·javascript·算法·矩阵
星释5 小时前
Rust 练习册 :Rail Fence Cipher与栅栏密码
开发语言·算法·rust