大厂算法题每日总结(绳子最大能盖的数组节点)
//绳子最大能盖的数组节点
public static void main(String[] args) {
int[] arr = {1,4,7,9,60};
System.out.println(maxPoint2(arr,50));
}
public static int maxPoint(int[] arr, int L) {//L是绳子的长度
int res =1;
for(int i =0;i<arr.length;i++) {
int nearest = nearestIndex(arr,i,arr[i]-L);
res = Math.max(res,i-nearest + 1);//(当前局部数组长度-起始下标)线段中间的节点+1
}
return res;
}
//方法一
public static int nearestIndex(int[] arr,int R,int value) {//二分查出绳子盖的起始下标位置
int L =0;
int index = R;
while(L <= R) {
int mid = L+ ((R-L)>> 1);
if(arr[mid]>=value) {
index = mid;
R = mid - 1;
} else {
L = mid+1;
}
}
return index;
}
//方法二
public static int maxPoint2(int[]arr, int L) {
int left = 0;
int right = 0;
int N =arr.length;
int max =0;
while(left < N) {
while(right < N && arr[right] - arr[left] <= L) {//窗口可移动,最大覆盖
right++;
}
max = Math.max(max,right-(left++));
}
return max;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报