滑动窗口一题

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

文章目录


前言


一、题目

二、代码

第一轮找数,第二轮扩充

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])会移动一次全部元素,也就是头插不好。

相关推荐
极创信息8 分钟前
信创产品认证怎么做?信创产品测试认证的主要流程
java·大数据·数据库·金融·软件工程
生成论实验室8 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星22 分钟前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
SamDeepThinking27 分钟前
并发量就算只有2,该上锁还得上呀
java·后端·架构
Sam_Deep_Thinking43 分钟前
如何让订单系统和营销系统解耦
java·架构·系统架构
lzhdim1 小时前
SQL 入门 12:SQL 视图:创建、修改与可更新视图
java·大数据·服务器·数据库·sql
科研前沿1 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨1 小时前
1931. 用三种不同颜色为网格涂色
算法·leetcode
晨曦夜月2 小时前
map与unordered_map区别
算法·哈希算法
FQNmxDG4S2 小时前
Maven依赖管理:版本冲突解决与生命周期控制
java·数据库·maven