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;
    }
}
相关推荐
pusue_the_sun23 分钟前
C语言强化训练(12)
c语言·开发语言·算法
圣保罗的大教堂26 分钟前
leetcode 2749. 得到整数零需要执行的最少操作数 中等
leetcode
小欣加油27 分钟前
leetcode 6 Z字形变化
c++·算法·leetcode·职场和发展
youzjuer39 分钟前
算法之二叉树
算法·深度优先
2401_858869801 小时前
支持向量机
算法·机器学习·支持向量机
用户4822137167751 小时前
深度学习——卷积神经网络
算法
DashingGuy1 小时前
算法(keep learning)
java·数据结构·算法
青鱼入云1 小时前
【面试场景题】spring应用启动时出现内存溢出怎么排查
spring·面试·职场和发展
兔兔西1 小时前
【数据结构、java学习】数组(Array)
java·数据结构·算法