标题:对局匹配

小明喜欢在一个围棋网站上找别人在线对弈。这个网站上所有注册用户都有一个积分,代表他的围棋水平。

小明发现网站的自动对局系统在匹配对手时,只会将积分差恰好是K的两名用户匹配在一起。如果两人分差小于或大于KK,系统都不会将他们匹配。

现在小明知道这个网站总共有NN名用户,以及他们的积分分别是A1,A2,…ANA1,A2,…AN。

小明想了解最多可能有多少名用户同时在线寻找对手,但是系统却一场对局都匹配不起来(任意两名用户积分差不等于KK)?

输入

第一行包含两个个整数N和K。

第二行包含N个整数A1, A2, … AN。

对于30%的数据,1 <= N <= 10

对于100%的数据,1 <= N <= 100000, 0 <= Ai <= 100000, 0 <= K <= 100000

输出

一个整数,代表答案。

样例输入:

10 0

1 4 2 8 5 7 1 4 2 8

样例输出:

6

样例输入:

10 1

2 1 1 1 1 4 4 3 4 4

样例输出:

8

资源约定:

峰值内存消耗 < 256M

CPU消耗 < 1000ms

请严格按要求输出,不要画蛇添足地打印类似:“请您输入…” 的多余内容。

所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。

注意: main函数需要返回0

注意: 只使用ANSI C/ANSI C++ 标准,不要调用依赖于编译环境或操作系统的特殊函数。

注意: 所有依赖的函数必须明确地在源文件中 #include , 不能通过工程设置而省略常用头文件。

提交时,注意选择所期望的编译器类型。

思路

  如果把nn个元素按照将分数相差为k的用户分成一组,例如第一组就是{0,k,2k,3k…}{0,k,2k,3k…},第二组就是{1,k+1,2k+1…}{1,k+1,2k+1…},等等。这样分组的话,每个分组的用户是不可能和其他分组的用户匹配成功的,因为分差不可能为kk。

  这样的话,只要在每个分组里面选取尽量多的用户就可以了。用cnt(i)cnt(i)表示分数为ii的用户人数,假设现在第ii组有mm个不同分数{x,x+k,x+2k,…,x+(m−1)k}{x,x+k,x+2k,…,x+(m−1)k},其中xx表示该组第一个人的积分,那么用动态规划法来选择尽量多的人数。dp(j)dp(j)表示选择前jj个分数能获得的最大用户人数(价值),很明显如果选择第jj个分数,那么第j−1j−1个分数是不能选的,因为它们的积分相差kk,该组最大在线人数为dp(m)dp(m)。

  状态转移方程如下:

dp(i)=max{dp(i−1),dp(i−2)+cnt(score)}dp(i)=max{dp(i−1),dp(i−2)+cnt(score)}

  其中cnt(score)cnt(score)表示积分为第ii个分数的总人数。是否感觉上述动态方程与01背包很类似?

需要注意的是,k=0k=0要特殊处理。

算法复杂度

O(100000)O(100000),只与最大分数有关。

AC代码

import java.util.Scanner;

public class duijupipei {
public static void main(String[] args) {
int res = 0;
Scanner cin = new Scanner(System.in);
int N = cin.nextInt();
int k = cin.nextInt();
int[] val = new int[100001];
//如果k不等于0,
for(int i=0;i<N;i++) {
val[cin.nextInt()]++;
}
cin.close();
if(k==0) {
for(int i=0;i<100001;i++) {
if(val[i]!=0) res++;
}
}
else {
int[] agroup = new int[100001];//一个组,每次循环,重新利用这个组
int[] dp = new int[100001];
//一共有k个组,循环每组,找出能过匹配的最大的人数
for(int i=0;i<k;i++) {
int len = 1;
for(int j=i;j<100001;j+=k) {
agroup[len++] = val[j];//当前组的第len个值为val[j]
}
dp[0] = 0;dp[1] = agroup[1];
for(int j=2;j<len;j++) {
dp[j] = Math.max(dp[j-1], dp[j-2]+agroup[j]);
}
res += dp[len-1];
}
}
System.out.println(res); } }

Java实现蓝桥杯第八届决赛 对局匹配的更多相关文章

  1. 日期求星期(java)-蓝桥杯

    日期求星期问题(java)-蓝桥杯 1:基姆拉尔森计算公式(计算星期) 公式: int week = (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)%7; 此处y,m,d指代年 ...

  2. Java实现 蓝桥杯VIP 基础练习 高精度加法

    java算法 蓝桥杯 高精度加法 问题描述 在C/C++语言中,整型所能表示的范围一般为-231到231(大约21亿),即使long long型,一般也只能表示到-263到263.要想计算更加规模的数 ...

  3. Java实现蓝桥杯 算法训练 ALGO-15 旅行家的预算

    问题描述 一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的).给定两个城市之间的距离D1.汽车油箱的容量C(以升为单位).每升汽油能行驶的距离D2.出发点每升汽油价格P和沿 ...

  4. Java实现 蓝桥杯VIP 基础练习 完美的代价

    package 蓝桥杯VIP; import java.util.Scanner; public class 完美的代价 { public static int sum = 0; public sta ...

  5. java实现 蓝桥杯 算法训练 Password Suspects

    问题描述 在年轻的时候,我们故事中的英雄--国王 Copa--他的私人数据并不是完全安全地隐蔽.对他来说是,这不可接受的.因此,他发明了一种密码,好记又难以破解.后来,他才知道这种密码是一个长度为奇数 ...

  6. java算法 蓝桥杯 乘法运算

    问题描述 编制一个乘法运算的程序. 从键盘读入2个100以内的正整数,进行乘法运算并以竖式输出. 输入格式 输入只有一行,是两个用空格隔开的数字,均在1~99之间(含1和99). 输出格式 输出为4行 ...

  7. java算法 蓝桥杯 扶老奶奶街

    一共有5个红领巾,编号分别为A.B.C.D.E,老奶奶被他们其中一个扶过了马路. 五个红领巾各自说话: A :我和E都没有扶老奶奶 B :老奶奶是被C和E其中一个扶过大街的 C :老奶奶是被我和D其中 ...

  8. java算法 蓝桥杯 高精度加法

    问题描述 在C/C++语言中,整型所能表示的范围一般为-231到231(大约21亿),即使long long型,一般也只能表示到-263到263.要想计算更加规模的数,就要用软件来扩展了,比如用数组或 ...

  9. java算法 蓝桥杯 格子位置

    问题描述 输入三个自然数N,i,j (1<=i<=N,1<=j<=N),输出在一个N*N格的棋盘中,与格子(i,j)同行.同列.同一对角线的所有格子的位置. 输入格式 输入共三 ...

随机推荐

  1. 【Spark】必须要用CDH版本的Spark?那你是不是需要重新编译?

    目录 为什么要重新编译? 步骤 一.下载Spark的源码 二.准备linux环境,安装必须软件 三.解压spark源码,修改配置,准备编译 四.开始编译 为什么要重新编译? 由于我们所有的环境统一使用 ...

  2. [hdu4123]dfs区间化+RMQ

    题意:给一个树编号0~n-1,一个数组a[i]为节点i在树上走的最大距离(不重复点),然后求最大的区间,使得区间最大差异小于某个值.dfs求出每个数组,同时区间化.枚举区间左边界,右边界同样递增,类似 ...

  3. angular js 分页

    一.编写实体类PageResult public class PageResult implements Serializable { private Long total;//总记录数 privat ...

  4. Codeforces1183C(C题)Computer Game

    Vova is playing a computer game. There are in total nn turns in the game and Vova really wants to pl ...

  5. python函数总结,你值得拥有

    目录 函数总结 函数定义与结构 函数名的使用 函数的参数 名称空间与作用域 名称空间 作用域 函数嵌套 内置函数(globals( ),locals( )) global+nonlocal 可迭代对象 ...

  6. 配置Universal Links

    参考: https://www.cnblogs.com/GJ-ios/p/9583141.html https://blog.csdn.net/saw471/article/details/10106 ...

  7. Ubuntu 安装 rabbitmq

    第一步:安装 erlang 官网:https://www.erlang-solutions.com/resources/download.html 然后在终端输入:erl 显示如下,说明安装成功! E ...

  8. Pyqt5_QPushButton

    QPushButton 状态 isDown() 提示按钮是否已按下 isChecked() 提示按钮是否已经标记 isEnable() 提示按钮是否可以被用户点击 isCheckAble() 提示按钮 ...

  9. #442-Find All Duplicates in an Array-数组中重复的数字

    一.题目 给定一个整数数组 a,其中1 ≤ a[i] ≤ n (n为数组长度), 其中有些元素出现两次而其他元素出现一次. 找到所有出现两次的元素. 你可以不用到任何额外空间并在O(n)时间复杂度内解 ...

  10. php 序列化

    PHP serialize() 函数 serialize() 函数用于序列化对象或数组,并返回一个字符串. serialize() 函数序列化对象后,可以很方便的将它传递给其他需要它的地方,且其类型和 ...