2023华为OD机试真题【实力差距最小总和】【2023.Q1】

题目描述

游戏里面,队伍通过匹配实力相近的对手进行对战。但是如果匹配的队伍实力相差太大,对于双方游戏体验都不会太好。
给定n个队伍的实力值,对其进行两两实力匹配,两支队伍实例差距在允许的最大差距d内,则可以匹配。要求在匹配队伍最多的情况下匹配出的各组实力差距的总和最小。
输入描述
第一行两个整数,n,d。队伍个数n。允许的最大实力差距d。
2<=n <=50
0<=d<=100
第二行,n个整数,表示队伍的实力值,以空格分割。
0<=各队伍实力值<=100
输出描述
输出一个整数,表示各组对战的实力差值的总和。若没有队伍可以匹配,则输出-1。
示例1:
输入
6 30
81 87 47 59 81 18
输出
57
示例2:
输入
6 20
81 87 47 59 81 18
输出
12

解题思路

dp1[i]表示在前i个队伍中,最多可以匹配的队伍数量。那么第 i 个元素如何推导呢?我需要考虑当前队伍和前一个队伍能否匹配。如果能匹配,那么dp1[i] 可以选择是dp1[i-2]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

codereasy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值