[CF 1780B] GCD Partition

B. GCD Partition#


题意 :
给一个长度为n的序列, 并将其分成连续的k(k > 1), 得到序列b, 使得 gcd(b1,b2,b3,...,bk) 的值最大


思路 : 数学 + 贪心 + 枚举
k = m时, 就能得到序列: b1,b2,b3,...,bm. 因为 b1b2 都是 gcd(b1,b2,b3,...,bm) 的公约数, 那么可得 b1+b2 也是 gcd(b1,b2,b3,...,bm) 的公约数, 所以有 gcd(b1,b2,b3,...,bm)gcd(b1+b2,b3,...,bm).

以此类推, 当k = 2 时,答案是最优情况, 那么就可以暴力枚举分成两份的情况


代码

#include <bits/stdc++.h>
using namespace std;

typedef long long LL;
const int N = 2e5 + 10;
int a[N];

int main() {
    int T;
    cin >> T;
    while (T--) {
        int n;
        scanf("%d", &n);
        LL sum = 0;
        for (int i = 0; i < n; i++) scanf("%d", &a[i]), sum += a[i];

        LL ans = 1, cur = 0;
        for (int i = 0; i < n - 1; i++) {
            cur += a[i], sum -= a[i];
            ans = max(ans, __gcd(cur, sum));
        }

        printf("%lld\n", ans);
    }

    return 0;
}

参考题解链接 : Codeforces Round #846 (Div. 2) — Tutorial - Codeforces

作者:Oneway

出处:https://www.cnblogs.com/oneway10101/p/17073657.html

版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。

posted @   Oneway`  阅读(83)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
more_horiz
keyboard_arrow_up dark_mode palette
选择主题
menu
点击右上角即可分享
微信分享提示