平分物品(网易2021校招笔试提前批)(dfs)

题目:

现在有n个物品,每一个物品都有一个价值,现在想将这些物品分给两个人,要求这两个人每一个人分到的物品的价值总和相同(个数可以不同,总价值相同即可),剩下的物品就需要扔掉,现在想知道最少需要扔多少价值的物品才能满足要求分给两个人。

在这里插入图片描述

这道题我认为是选择问题 通过dfs每一种可能的选择,找到所有可能的解法

题意转换

​ 将题意转换很重要,题目是求最少丢掉多少物品能够平分给两个人,转换为两个人从0开始拿,计算出所有满足平分条件的最值(最少丢弃)

具体步骤

  1. 首先将题目转换为两个人从0开始拿物品,对于每一件物品开始进行选择,对于每个物品有三种选择,给第一个人、给第二个人、丢掉。

2.参数说明:nums记录n个物品的价值 ;result1、result2记录两个人目前分别拿了多少;sum记录所有元素总和,index记录选择进行到哪个元素了,n记录总共有多少个需要选择的物品

3.选择结束条件:搜索到最后一个物品 判断两者是否相等 相等则记录此时的最值

#include<iostream>
using namespace std;
#include<vector>
#include<algorithm>
#include<bits/stdc++.h>
//定义两组数据的累加和  从0开始dfs每种可能,遇到两者相同的情况,就记录此时需要扔掉
//选择问题  两个人从0开始拿物品,遇到一个物品有三种选择,给第一个人,给第二个人,扔掉。
//走到结尾就找到舍弃价值最小的那一个节点
 
int res = INT_MAX;//最小扔掉的价值
void dfs(vector&
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值