【倒着考虑】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;
}
相关推荐
草莓火锅2 小时前
用c++使输入的数字各个位上数字反转得到一个新数
开发语言·c++·算法
散峰而望2 小时前
C/C++输入输出初级(一) (算法竞赛)
c语言·开发语言·c++·算法·github
Kuo-Teng2 小时前
LeetCode 160: Intersection of Two Linked Lists
java·算法·leetcode·职场和发展
fie88892 小时前
基于MATLAB的狼群算法实现
开发语言·算法·matlab
偷偷的卷3 小时前
【算法笔记 11】贪心策略六
笔记·算法
ZPC82103 小时前
FPGA 部署ONNX
人工智能·python·算法·机器人
_w_z_j_4 小时前
爱丽丝的人偶
算法
老前端的功夫4 小时前
Vue2中key的深度解析:Diff算法的性能优化之道
前端·javascript·vue.js·算法·性能优化
yongui478345 小时前
基于深度随机森林(Deep Forest)的分类算法实现
算法·随机森林·分类
是苏浙5 小时前
零基础入门C语言之C语言实现数据结构之单链表经典算法
c语言·开发语言·数据结构·算法