HJ93 数组分组

知识点字符串递归

描述

对于给定的 n 个整数 a1,a2,...,an,将其分为 a,b 两个数组,满足:

∙ ∙所有 5 的倍数元素均在 a 数组中;

∙ ∙所有 3 的倍数元素(不包括 5 的倍数)均在 b 数组中;

∙ ∙其他元素可以任意分配。

求解是否存在一种分配方案,使得 a 数组中各个元素之和等于 b 数组中各个元素之和。每一个元素要么在 a 数组中,要么在 b 数组中;数组可以为空,此时和为 0。如果存在这样的方案,输出 true,否则输出 false。

输入描述:

第一行输入一个整数 n(1≦n≦30)代表给定的整数个数。

第二行输入 n 个整数 a1,a2,...,an(−500≦ai≦500)。

保证数据随机生成。

输出描述:

如果存在满足条件的分配方案,输出 true,否则输出false。

示例1

输入:

复制代码
4
1 5 -5 1

输出:

复制代码
true

说明:

复制代码
在这个样例中,a 数组可以为 {5,−5,1},b 数组可以为 {1},满足条件。

示例2

输入:

复制代码
3
3 5 8

输出:

复制代码
false
cpp 复制代码
#include<iostream>
#include<algorithm>
#include<vector>
#include<unordered_set>
using namespace std;

int main(){
    int n;
    while(cin >> n){
        vector<int> arr;
        int sum3 = 0;
        int sum5 = 0;
        int rest = 0;
        for(int i = 0; i < n; i++){ 
            int x;
            cin >> x;
            if(x % 5 == 0) //先求一个组的和
                sum5 += x;
            else if(x % 3 == 0) //再求另一个组的和
                sum3 += x;
            else{
                arr.push_back(x); //剩余的加入数组并求和
                rest += x;
            }
        }
        unordered_set<int> s1, s2;
        s1.insert(0); //枚举所有组合的不重复和,0为空数组
        for(int i = 0; i < arr.size(); i++){ //遍历每一个数字
            s2 = s1; //每个数字都要与当前集合的每个数相加组成新的和
            for(auto it: s2)
                s1.insert(it + arr[i]);
        }
        bool flag = false;
        for(auto it: s1){ //遍历枚举的集合
            if(it + sum5 == sum3 + rest - it){ //分成两部分后相等
                flag = true;
                break;
            }
        }
        cout << (flag ? "true" : "false") << endl;
    }
    return 0;
}
相关推荐
ChillCoding4 分钟前
更新中:C++ STL库,查找排序(基础算法),数据结构,数学算法,竞赛相关基础
数据结构·c++·算法
智者知已应修善业9 分钟前
【51单片机使用IO组赋值方法实现无源蜂鸣器响时LED12亮不响时34亮】2024-3-7
c++·经验分享·笔记·算法·51单片机
.千余11 分钟前
【C++】深挖STL list底层:解迭代器与节点存储逻辑
开发语言·c++·笔记·学习·其他
雪落漂泊13 分钟前
C++ 继承与多态(上)
开发语言·c++
聆风吟º19 分钟前
【C++11新章】列表初始化详解
开发语言·c++·列表初始化
珊瑚里的鱼19 分钟前
【动态规划】按摩师
算法·动态规划
Fms_Sa19 分钟前
贪心算法-背包问题
算法·贪心算法·c#
alwaysrun20 分钟前
C++之灵活易用的YAML解析库yaml-cpp
c++·后端·程序员
大雨淅淅25 分钟前
【机器人】ROS2 机械臂控制(MoveIt2)从入门到实战
人工智能·python·神经网络·学习·算法·机器学习·机器人
Shadow(⊙o⊙)32 分钟前
进程间通信0.0-pipe()匿名管道,详细分析进程池调度队列执行逻辑,进程池模拟实现。
linux·运维·服务器·开发语言·c++