【倒着考虑】CF Edu 21 D

Problem - D - Codeforces

题意:

思路:

这道题需要倒着步骤考虑,就是先去假设已经分为了两部分,这左右两部分的和相等,然后去想上一个步骤

倒着一个步骤后,可以发现这样的性质:

Code:

cpp 复制代码
#include <bits/stdc++.h>

#define int long long

using i64 = long long;

constexpr int N = 1e5 + 10;
constexpr int M = 1e5 + 10;
constexpr int P = 2600;
constexpr i64 Inf = 1e18;
constexpr int mod = 1e9 + 7;
constexpr double eps = 1e-6;

int n;
int a[N];

void solve() {
    std::cin >> n;

    std::map<int,int> mp, mp2;
    int sum = 0;
    for (int i = 1; i <= n; i ++) {
        std::cin >> a[i];
        sum += a[i];
        mp2[a[i]] ++;
    }

    if (sum & 1) {
        std::cout << "NO" << "\n";
        return;
    }

    int s = 0;
    for (int i = 1; i <= n; i ++) {
        s += a[i];
        mp[a[i]] ++;
        mp2[a[i]] --;
        if (s > sum / 2) {
            if (mp[s - sum / 2]) {
                std::cout << "YES" << "\n";
                return;
            }
        }else if (s < sum / 2) {
            if (mp2[sum / 2 - s]) {
                std::cout << "YES" << "\n";
                return;
            }
        }else {
            std::cout << "YES" << "\n";
            return;
        }
    }

    std::cout << "NO" << "\n";
}
signed main() {
    std::ios::sync_with_stdio(false);
    std::cin.tie(nullptr);
    
    int t = 1;

    while (t--) {
        solve();
    }
    
    return 0;
}
相关推荐
hellBaron1 小时前
C语言宏和结构体的使用代码
c语言·数据结构·算法
yannan201903131 小时前
【数据结构】(Python)差分数组。差分数组与树状数组结合
开发语言·python·算法
我的运维人生2 小时前
机器学习算法深度解析:以支持向量机(SVM)为例的实践应用
算法·机器学习·支持向量机·运维开发·技术共享
shinelord明4 小时前
【再谈设计模式】策略模式 ~ 算法与行为的灵活调度员
开发语言·数据结构·算法·设计模式·数据分析·软件工程
走向自由4 小时前
[Leetcode] 最大子数组和 [击败99%的解法]
算法·leetcode·职场和发展
sjsjs114 小时前
【数据结构-单调队列】力扣2762. 不间断子数组
数据结构·算法·leetcode
OTWOL5 小时前
【单链表】 OJ 练习题精选
c语言·开发语言·数据结构·c++·算法
是wzoi的一名用户啊~5 小时前
[wzoi]Help Bubu
开发语言·c++·算法
chenziang15 小时前
leetcode hot 100 划分字母区间
算法·leetcode·职场和发展
虾球xz5 小时前
游戏引擎学习第70天
学习·算法·游戏引擎