ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2020-06-12 22:53:00  阅读:289  来源: 互联网

标签:练习赛 mathit ll 牛客 65 ans repd MOD


牛客练习赛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取模的值

思路:

贪心思路:

将数组\(\mathit a\)排序一下,前\(n/2\)个一定是加起来,后\(n/2\)个,如果大于1就乘,否则就加。

证明:

假设前\(n/2\)个中有个数\(\mathit x\)为乘骑来,那么一定会让后\(n/2\)个中某个数\(\mathit y\)是加起来,

因为\(x\leq y\)那么\((A+y)*x\leq(A+x)*y\),所以假设不是最优。

代码:

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;
}

标签:练习赛,mathit,ll,牛客,65,ans,repd,MOD
来源: https://www.cnblogs.com/qieqiemin/p/13110977.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有