牛客网-小美的加法(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;
}
相关推荐
CHANG_THE_WORLD28 分钟前
switch语句在汇编层面的几种优化方式 ,为什么能进行优化
汇编·算法·switch·汇编分析·switch case·switch case 汇编·switch case 语句
山,离天三尺三29 分钟前
深度拷贝详解
开发语言·c++·算法
Blossom.11837 分钟前
把AI“撒”进农田:基于极值量化与状态机的1KB边缘灌溉决策树
人工智能·python·深度学习·算法·目标检测·决策树·机器学习
一只鱼^_1 小时前
第 167 场双周赛 / 第 471 场周赛
数据结构·b树·算法·leetcode·深度优先·近邻算法·迭代加深
被制作时长两年半的个人练习生1 小时前
近期的笔试和面试的复盘
算法·面试·职场和发展·算子
gsfl2 小时前
贪心算法1
算法·贪心算法
小猪咪piggy2 小时前
【算法】day8 二分查找+前缀和
算法
Word码2 小时前
[排序算法]希尔排序
c语言·数据结构·算法·排序算法
前端小刘哥3 小时前
解析视频直播点播平台EasyDSS在视频点播领域的技术架构与性能优势
算法
QT 小鲜肉3 小时前
【数据结构与算法基础】05. 栈详解(C++ 实战)
开发语言·数据结构·c++·笔记·学习·算法·学习方法