【倒着考虑】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;
}
相关推荐
shangjian0071 小时前
AI大模型-评价指标-相关术语
人工智能·算法
Live&&learn2 小时前
算法训练-数据结构
数据结构·算法·leetcode
松岛雾奈.2303 小时前
机器学习--PCA降维算法
人工智能·算法·机器学习
电子_咸鱼4 小时前
【STL string 全解析:接口详解、测试实战与模拟实现】
开发语言·c++·vscode·python·算法·leetcode
sweet丶4 小时前
适合iOS开发的一种缓存策略YYCache库 的原理
算法·架构
是宇写的啊4 小时前
算法—滑动窗口
算法
风筝在晴天搁浅4 小时前
代码随想录 509.斐波那契数
数据结构·算法
落落落sss4 小时前
java实现排序
java·数据结构·算法
limenga1025 小时前
支持向量机(SVM)深度解析:理解最大间隔原理
算法·机器学习·支持向量机
coder江5 小时前
二分查找刷题总结
算法