题目描述
游戏里面,队伍通过匹配实力相近的对手进行对战。但是如果匹配的队伍实力相差太大,对于双方游戏体验都不会太好。
给定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]