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;
}
相关推荐
Qt程序员12 小时前
基于 C++ 实现自定义字符串 string 类
linux·c++·容器·指针·内存管理·运算符重载
Ivanqhz12 小时前
活跃范围重写(Live Range Rewriting)
开发语言·c++·后端·算法·rust
xiaoye-duck12 小时前
《算法题讲解指南:优选算法-链表》--51.两数相加,52.两两交换链表中的节点
数据结构·算法·链表
Cosolar12 小时前
阿里CoPaw进阶使用手册:从新手到高手的完整指南
人工智能·后端·算法
松小白song12 小时前
机器人路径规划算法之Dijkstra算法详解+MATLAB代码实现
前端·javascript·算法
qq_263_tohua12 小时前
第107期 刷算法题
算法
2501_9403152612 小时前
98验证二叉搜索树
java·数据结构·算法
luckycoding12 小时前
3005. 最大频率元素计数
算法·leetcode·职场和发展
像污秽一样12 小时前
算法设计与分析-算法效率分析基础-分治法
算法·排序算法
我能坚持多久12 小时前
栈与队列OJ问题详解
算法