【ybtoj】拔河比赛

本文介绍了拔河比赛的公平性要求,即人数最多相差1,体重和相差最小。给出的解题思路是通过遍历所有可能的人员选择方案,找到使两边体重差值最小的分配方法。并提供了一个样例输入和输出。
部署运行你感兴趣的模型镜像

拔河比赛


题目描述

学校组织了一场拔河比赛,为了拔河比赛的公平性,老师提出以下要求:
(1)拔河比赛两边人数最多相差1
(2)每个队员都有体重,我们要使两边比赛的人体重和相差最小。
现在有N个队员,老师想让你帮忙分配,并且把分配后两边体重和只差最小值输出。

输入格式

首先输入T,表示有T组样例。
每个样例:
首先输入人数N,占一行。
后面跟着N个数,表示N个人的体重W1W_1W1 ~ WnW_nWn

输出格式

每组数据输出一行,一个整数表示两边体重只差的绝对值。

样例输入

1
3
55 50 100

样例输出

5

解题思路

遍历每一个人,要么选,要么不选,并且保证总人数为2/n2/n2/n,在所有方案中找出最小的差值,就是我们的答案

Code

#include <iostream>
#include <cstdio>
#include <cmath>
using namespace std;
const int maxn=0x7fffffff;
int T,n,ans,a[30];
void dfs(int x,int lr,int rr,int ls,int rs)
{
	if(x>n) //判断人数平衡
	{
		if(abs(lr-rr)>1) 
		 return;
		ans=min(ans,abs(ls-rs));
		return;
	}
	dfs(x+1,lr,rr+1,ls,rs+a[x]);
	dfs(x+1,lr+1,rr,ls+a[x],rs);
}
int main(){
	scanf("%d",&T);
	while (T--) 
	{
		ans=maxn;
		scanf("%d",&n);
		for(int i= 1;i<=n;i++)
		 scanf("%d",&a[i]);
		dfs(1,0,0,0,0);
		printf("%d\n",ans);
	}
}

谢谢阅读

您可能感兴趣的与本文相关的镜像

Wan2.2-T2V-A5B

Wan2.2-T2V-A5B

文生视频
Wan2.2

Wan2.2是由通义万相开源高效文本到视频生成模型,是有​50亿参数的轻量级视频生成模型,专为快速内容创作优化。支持480P视频生成,具备优秀的时序连贯性和运动推理能力

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值