题解 | 相差不超过k的最多数
相差不超过k的最多数
https://www.nowcoder.com/practice/562630ca90ac40ce89443c91060574c6
import java.util.Scanner; import java.util.*; // 注意类名必须为 Main, 不要有任何 package xxx 信息 public class Main { public static void main(String[] args) { Scanner in = new Scanner(System.in); // 注意 hasNext 和 hasNextLine 的区别 while (in.hasNextInt()) { // 注意 while 处理多个 case int a = in.nextInt(); int s = in.nextInt(); int[] data = new int[a]; for (int i = 0; i < a; i++) { data[i] = in.nextInt(); } Arrays.sort(data); int res = 0; Arrays.sort(data); int curr = 1; for (int i = 0; i < data.length; i++) { for (int j = curr; j < data.length; j++) { if (Math.abs(data[j] - data[i]) > s) { res = Math.max(res, j - i); curr = j; break; } if (j == data.length - 1) { res = Math.max(res, data.length - i); break; } } } System.out.println(res); } } }