LeetCode 3423. 循环数组中相邻元素的最大差值 题解

示例如下:

复制代码
输入:nums = [1,2,4]

输出:3

解释:

由于 nums 是循环的,nums[0] 和 nums[2] 是相邻的,它们之间的绝对差值是最大值 |4 - 1| = 3。

其实就是把该数组相像成一个闭环的圈形数组,首尾相连,那么我们只需要分类讨论即可,第一点是当遍历头节点i=0时,其左节点是i=n-1,其右节点是i=1,第二点是当遍历尾节点i=n-1时,其左节点是i=n-2,右节点是i=0,第三点是正常遍历i,其左节点是i-1,右节点是i+1,所以代码如下

复制代码
class Solution {
    public int maxAdjacentDistance(int[] nums) {
        int n = nums.length;
        int l=0;
        int r=0;
        int max = 0;
        int ans = 0;
        for(int i=0;i<n;i++){
            if(i==0){
                l=n-1;
                r=1;
            }
            else if(i==n-1){
                l=n-2;
                r=0;
            }
            else{
                l=i-1;
                r=i+1;
            }
            max = Math.max(Math.abs(nums[l]-nums[i]),Math.abs(nums[r]-nums[i]));
            ans = Math.max(max,ans);
        }
        return ans;
    }
}
相关推荐
静水流深-刘申28 分钟前
算法继续刷起-2025年09月26日
开发语言·c++·算法
木头左1 小时前
跨周期共振效应在ETF网格参数适配中的应用技巧
开发语言·python·算法
MongoVIP1 小时前
AI提示词应用
人工智能·职场和发展·简历优化·简历制作
顾你&2 小时前
机器学习之无监督学习算法大总结
学习·算法·机器学习
神龙斗士2402 小时前
Java 数组的定义与使用
java·开发语言·数据结构·算法
Y.O.U..2 小时前
力扣HOT100-跳跃游戏II
算法·leetcode
hn小菜鸡2 小时前
LeetCode 3132.找出与数组相加的整数 II
算法·leetcode·职场和发展
微笑尅乐2 小时前
数组模拟加法——力扣66.加一
算法·leetcode·职场和发展
_不会dp不改名_3 小时前
leetcode_146 LRU缓存
算法·leetcode·缓存
aloha_7893 小时前
新国都面试真题
jvm·spring boot·spring·面试·职场和发展