刷题笔记之数组

这篇博客主要探讨数组的基本操作,如搜索插入位置、合并区间和寻找中心下标,以及二维数组的旋转。此外,还详细介绍了双指针技巧,包括从两端向中间迭代和快慢指针的应用,如字符串反转、两数之和和移除元素。文章提供了相关题目的分析和解题代码。
摘要由CSDN通过智能技术生成

前言

本博客是对数组做相关练习时所做笔记,主要内容来源于数组与字符串
本文主要介绍了数组的基本操作以及数组常用的技巧——双指针,并对相关题目附上题解,其中双指针包括从两端向中间迭代数组和快慢指针两种技巧。

数组的基本操作

数组的特点:连续存储、可通过索引直接访问;查找方便,增删困难。

35.搜索插入位置

  • 题目描述:给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
    你可以假设数组中无重复元素。

  • 示例

    输入: [1,3,5,6], 5
    输出: 2
    输入: [1,3,5,6], 7
    输出: 4
    
  • 分析:转化为找到第一个大于等于target的数组下标,可使用二分查找。

  • 代码

    public int searchInsert(int[] nums, int target) {
         
        //二分查找
        int l = 0, r = nums.length;
        while(l < r) {
         
            int m = l + (r - l) / 2;
            //当前值大于等于target
            if(nums[m] >= target) r = m;
            //当前值小于target
            else l = m + 1;
        }
        return l;
    }
    

56.合并区间

  • 题目描述:以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间。其中0 <= starti <= endi。

  • 示例

    输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
    输出:[[1,6],[8,10],[15,18]]
    解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].
    
    输入:intervals = [[1,4],[4,5]]
    输出:[[1,5]]
    解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。
    
  • 分析:先按头部从小到大排序,再合并。

  • 代码

    public int[][] merge(int[][] intervals) {
         
        //对二维数组按照首元素值从小到大排序
        Arrays.sort(intervals, (a, b) -> a[0] - b[0]);
    
        List<int[]> ans = new ArrayList<>();
        for (int[] cur : intervals) {
         
            int l = cur[0];
            int r = cur[1];
            if (ans.size() == 0 || l > ans.get(ans.size() - 1)[1]) {
         
                ans.add(cur);
            } else {
         
                //重合时,更新list最后一个区间的右端点
                ans.get(ans.size() - 1)[1] = Math.max(ans.get(ans.size() - 1)[1], r);
            }
        }
    
        return ans.toArray(new int[ans.size()][]);
    }
    

724.寻找数组的中心下标

  • 题目描述:给你一个整数数组 nums,请编写一个能够返回数组 “中心下标” 的方法。数组 中心下标 是数组的一个下标,其左侧所有元素相加的和等于右侧所有元素相加的和。如果数组不存在中心下标,返回 -1 。如果数组有多个中心下标,应该返回最靠近左边的那一个。
    注意:中心下标可能出现在数组的两端。

  • 分析:题目较简单,从左到右遍历每一个元素,判断该元素是否为中心元素即可。

  • 代码

    public int pivotIndex(int[] nums) {
         
        if (nums.length == 0) return -1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值