滑动窗口一题

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


前言


一、题目

二、代码

第一轮找数,第二轮扩充

java 复制代码
class Solution {
    public List<Integer> findClosestElements(int[] arr, int k, int x) {
        int l=0,r=0,i=1;
        int n=arr.length;
        List<Integer> a1=new ArrayList<Integer>();
        while(n>1 && r-l+1<=k && i<n){
            if(arr[i-1]==arr[i]){
                i++;
                continue;
            }
            if(Math.abs(arr[i-1]-x)<=Math.abs(arr[i]-x)){
                r=i-1;
                l=r;//偏左
                break;
            }else{
                i++;
            }
        }
       if(i!=n) {
            a1.add(arr[r]);
        }else {
            r=i-1;
            l=r;
            a1.add(arr[n-1]);
        }
        while(a1.size()<k){
            if(l-1<0){
                a1.add(arr[r+1]);
                r++;
                continue;
            }
            if(r+1==n){
                a1.add(0,arr[l-1]);
                l--;
                continue;
            }
            if(Math.abs(arr[l-1]-x)<=Math.abs(arr[r+1]-x)){
                a1.add(0,arr[l-1]);
                l--;
            }else{
                a1.add(arr[r+1]);
                r++;
            }
        }
        return a1;
    }
}

总结

写的不好,暂时还没发现原因。

这题是定长数组。

现在开始看标答,发现原因。

思路都差不多,1.确定好下标后依次加入2.ArrayList.add(0,arr[i])会移动一次全部元素,也就是头插不好。

相关推荐
专注VB编程开发20年3 分钟前
压栈顺序是反向(从右往左)的,但正因为是反向压栈,所以第一个参数反而离栈顶(ESP)最近。
java·开发语言·算法
椰汁菠萝3 分钟前
spring boot下使用gdal解析tif文件
java·native·gdal·0
Xの哲學4 分钟前
Linux Select 工作原理深度剖析: 从设计思想到实现细节
linux·服务器·网络·算法·边缘计算
better_liang4 分钟前
每日Java面试场景题知识点之-ELK日志分析
java·elk·微服务·面试题·日志分析·企业级开发
图南随笔8 分钟前
Spring Boot(二十三):RedisTemplate的Set和Sorted Set类型操作
java·spring boot·redis·后端·缓存
say_fall8 分钟前
C++ 类与对象易错点:初始化列表顺序 / 静态成员访问 / 隐式类型转换
android·java·开发语言·c++
Paul_092022 分钟前
golang编程题
开发语言·算法·golang
pyniu23 分钟前
Spring Boot车辆管理系统实战开发
java·spring boot·后端
虾说羊24 分钟前
ssm项目本地部署
java·tomcat