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;
}
相关推荐
Irissgwe13 分钟前
类与对象(三)
开发语言·c++·类和对象·友元
️是7825 分钟前
信息奥赛一本通—编程启蒙(3395:练68.3 车牌问题)
数据结构·c++·算法
Liangwei Lin41 分钟前
LeetCode 118. 杨辉三角
算法·leetcode·职场和发展
计算机安禾44 分钟前
【c++面向对象编程】第24篇:类型转换运算符:自定义隐式转换与explicit
java·c++·算法
鼠鼠我(‘-ωก̀ )好困1 小时前
leetGPU
算法
雪度娃娃1 小时前
转向现代C++——优先选用nullptr而不是0和NULL
开发语言·c++
我星期八休息1 小时前
Linux系统编程—基础IO
linux·运维·服务器·c语言·c++·人工智能·算法
池塘的蜗牛1 小时前
A Low-Complexity Method for FFT-based OFDM Sensing
算法
故事和你912 小时前
洛谷-【图论2-1】树5
开发语言·数据结构·c++·算法·动态规划·图论
咖啡里的茶i2 小时前
视觉显著目标的自适应分割与动态网格生成算法研究
人工智能·算法·目标跟踪