题解 | #数组分组#

数组分组

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;
        
    }
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-26 18:54
说等下个版本吧的发呆爱好者很贪睡:佬最后去了哪家呀
点赞 评论 收藏
分享
秋招进行到现在终于能写总结了。完全没想到战线会拉这么长,过程会如此狼狈,不过更应该怪自己太菜了。好在所有的运气都用在了最后,也是有个去处。背景:双2本硕科班,无竞赛,本科一段研究所实习,硕士一段大厂暑期实习但无转正。技术栈是C++&nbsp;&amp;&nbsp;Golang,实习是客户端音视频(而且是鸿蒙端开发),简历两个C++项目一个Golang项目。主要投递岗位:后端,cpp软开,游戏服务端,测开,以及一些不拘泥于Java的岗位。从8月起总共投递123家公司,笔试数不清了,约面大约30家。offer/oc/意向:友塔游戏(第一个offer,面试体验很好,就是给钱好少南瑞继保(计算机科班点击就送(限男生),不...
乡土丁真真:佬很厉害,羡慕~虽然我还没有到校招的时候,也想讲一下自己的看法:我觉得不是CPP的问题,佬的背书双2,技术栈加了GO,有两段实习。投了123,面了30.拿到11个offer。这个数据已经很耀眼了。这不也是CPP带来的吗?当然也不止是CPP。至少来说在这个方向努力过的也会有好的结果和选择。同等学历和项目选java就会有更好的吗?我个人持疑问态度。当然CPP在方向选择上确实让人头大,但是我觉得能上岸,至于最后做什么方向,在我看来并不重要。至于CPP特殊,有岗位方向的随机性,java不是不挑方向,只是没得选而已。也希望自己以后校招的时候能offer满满
点赞 评论 收藏
分享
11-07 13:31
怀化学院 Java
勇敢牛牛不怕难:又疯一个
点赞 评论 收藏
分享
评论
点赞
1
分享
牛客网
牛客企业服务