牛客练习赛65 - A 最值序列 (贪心)

牛客练习赛65 - A 最值序列 (贪心)

链接:https://ac.nowcoder.com/acm/contest/5961/A
来源:牛客网

题目描述

给一个长度为n的序列aia_iai,一开始你有一个数A = 0,每次可以从序列中选一个数b,令A = A + b或者A = A * b,每个数都要使用一次,加的次数要和乘的次数相同,要求最大化A,输出A对998244353取模的值

思路:

贪心思路:

将数组排序一下,前个一定是加起来,后个,如果大于1就乘,否则就加。

证明:

假设前个中有个数为乘骑来,那么一定会让后个中某个数是加起来,

因为那么,所以假设不是最优。

代码:

int n;
ll a[maxn];
const ll MOD = 998244353ll;
int main()
{
#if DEBUG_Switch
    freopen("C:\\code\\input.txt", "r", stdin);
#endif
    //freopen("C:\\code\\output.txt","r",stdin);
    cin >> n;
    repd(i, 1, n)
    {
        cin >> a[i];
    }
    sort(a + 1, a + 1 + n);
    ll ans = 0ll;
    repd(i, 1, n / 2)
    {
        ans += a[i];
        ans %= MOD;
    }
    repd(i, n / 2 + 1, n)
    {
        if (a[i] > 1)
        {
            ans = ans * a[i] % MOD;
        } else
        {
            ans = (ans + a[i]) % MOD;
        }
    }
    printf("%lld\n", ans );
    return 0;
}
ACM训练题解报告 文章被收录于专栏

ACM训练题解报告,400余篇题解,涉及各大主流OJ平台。

全部评论

相关推荐

03-01 21:45
中北大学 Python
孤蓝长空:请你说一下为什么你用websocket而不是http,请你说一下什么是rpc,为什么用rpc,你的rpc的传输协议是JSON,xml还是什么 请你描述一下你的鉴权流程(完整的) 我问的是第二个项目,随便问的哈哈哈
开工第一帖
点赞 评论 收藏
分享
求问!考研下岸,打算参加春招,我这个bg能进啥厂,或者需要搞点深度项目再投吗
Java抽象带篮子_...:直接海投,可以看看我的考研失利速成冲春招贴,里面详细写了简历怎么写,学哪些项目可以速成
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务