题解 | #数组分组#

数组分组

http://www.nowcoder.com/practice/9af744a3517440508dbeb297020aca86

动态规划,想办法转化力扣的416题,分割相等其实就是找一个集合使它们中有数的组合可以加起来等于某个数,而这个数在416题是和的一半,我这里就是x/2

#include <algorithm>
#include <vector>

using namespace std;

bool judge(int sum5,int sum3,int nor35,vector<int>&v){
    
    int diff = abs(sum5-sum3);
    if(nor35==0&&(diff==0)) return true;//这里的逻辑好理解差值为0,且没有第三组
    int x = nor35+diff;//这里求和想看看它们能否被评分因为整个集合都是整数,如果是
    //奇数除以2是小数,不可能又和可以组成,只有能平分成整数在考虑有没有数可以组合。
    if(diff==0&&(v.size()==0))return true;
    
    if(x%2!=0) return false;
    else{
        x/=2;
        vector<vector<int>> dp(v.size(),vector<int>(x+1,0));
        for(int i =0;i<v.size();i++){
            dp[i][0]=1;
        }
       
            dp[0][v[0]]=1;
        
        
        for(int i = 1;i<v.size();i++){
            for(int j =1;j<x+1;j++){
                if(j>=v[i])dp[i][j]=dp[i-1][j-v[i]]||dp[i-1][j];//这里i-1代表
                //没有v[i]的时候的和也可以组成j
                else dp[i][j]=dp[i-1][j];
            }
        }
        return dp[v.size()-1][x];
       
    }
     
    
}

int main() {
    int n;
    while(cin>>n){
        vector<int> v;
        int sum5=0,sum3=0,sum=0,nor35=0;
        int temp;
        for(int i =0;i<n;i++){
            cin>>temp;
            if(temp%5==0){
                sum5+=temp;
            }
            else if(temp%3==0){
                sum3+=temp;
            }
            else{
                nor35+=abs(temp);//加绝对值对最后判断能不能分成两个和相等时没有
                //影响,不信你自己试试看
                v.push_back(abs(temp));
            }
            
        }
        bool canpatiton = false;
            canpatiton = judge(sum5,sum3,nor35,v);
            cout<<boolalpha<<canpatiton<<endl;
        
    }
}
全部评论

相关推荐

2025-11-30 21:55
哈尔滨华德学院 Java
高通滤波器v:我最近投的几个,都是要不已读不回,要不不回,还有直接拒绝的
点赞 评论 收藏
分享
2025-12-01 10:57
已编辑
云智研发公司_后台开发
先说明一下&nbsp;bg双非本,没有特别加分的竞赛奖项,只有一些省奖作为25入职的校招生我想我我入职体验是最新鲜的面试准备,工作体验(本人是研发岗)1、首先作为一个实习经历并不多的双非本来说,我能过筛选已经很出乎意外了,所以我格外重视这次面试①首先就是算法题,我在力扣刷了两遍的hot100,最起码我认为我不能在算法题上失误②其次我在牛客网和小红书上看了很多的面经,包括一些自我介绍,一些面试技巧等tips:①简历中的内容一定要理解透彻,面试官可能问到简历中的各种内容②如果在面试中遇到不会的问题,可以直接说明,面试官可以理解校招同学我只能说足够的准备才能不浪费一次面试的机会2、入职以后,我最大的体验就是同事之间的互相帮助,大家不会一个简单的问题就不耐烦,反而会问你有没有理解,可以重复的帮助你①入职后,工作上不理解的一定要积极的询问同事或者导师或者leader,大家对于校招同学有些很高的包容性,面对其他问题可以问hr②新入职都可能存在彷徨,有压力,毕竟入职一定是需要学习新的知识,但是可以化压力为动力,努力学习3、最后我想说的,云智大家庭是一个包容性很强很温暖的大家庭,没有学历歧视,没有经验歧视,没有地域歧视,没有职位歧视,只有一起共同进步的目标,欢迎大家向云智投出简历(我本人在武汉腾讯云智,有想咨询的问题可以私聊我)ps:图一是入职培训优秀小组
面了100年面试不知...:是谁有鹅仔
腾讯云智研发成长空间 5107人发布
点赞 评论 收藏
分享
2025-12-27 22:35
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务