Java旋转数组中的最小数字(图文详解版)

简介: 1.题目描述2.题解分析具体实现方法一(遍历):方法二(排序):方法三(二分查找):

1.题目描述

有一个长度为 n 的非降序数组,比如[1,2,3,4,5],将它进行旋转,即把一个数组最开始的若干个元素搬到数组的末尾,变成一个旋转数组,比如变成了[3,4,5,1,2],或者[4,5,1,2,3]这样的。请问,给定这样一个旋转数组,求数组中的最小值。


示例


输入:[3, 4, 5, 1, 2]

返回值:1


2.题解


分析

题目中的数组为


b5f9b8f525234317a701ff8cce70b96b.png


题目要求我们找出其中的最小值


具体实现

方法一(遍历):

寻找数组中的最小值,遍历数组即可找到最小值

publicclassSolution {
publicintminNumberInRotateArray(int[] nums) {
if(nums.length==0){
return-1;
        }
intmin=nums[0];
for (inti=1; i<nums.length; i++) {
if (min>nums[i]) {
min=nums[i];
            }
        }
returnmin;
    }
}


方法二(排序):

使用Arrays.sort方法对数组进行降序排序,则nums[0]即为数组的最小值

importjava.util.Arrays;
publicclassSolution {
publicintminNumberInRotateArray (int[] nums) {
if(nums.length==0){
return-1;
        }
Arrays.sort(nums);
returnnums[0];
    }
}


方法三(二分查找):

数组原本是一个升序数组,旋转之后,数组被分成两部分,前、后半部分分别为升序,后半部分小于前半部分,我们可以利用二分查找的思想,找到其旋转点,即可找到数组的最小值


首先找到数组首尾两端元素,并求出数组中间的下标


ef90ab01fa11427d83e9a4c04007f798.png


再将数组中间值与数组首尾两端元素进行比较,


nums[mid] > nums[right],则left = mid + 1ef90ab01fa11427d83e9a4c04007f798.png

nums[mid] < nums[right],则right = mid


1f22f78dbd84491eb7f2858054f58ea3.png


nums[mid] = nums[right], 则将right向左移动一位,即right--


38f76fb7138a41468f928280eebf8c2a.png


然后进入下一次循环,循环的条件为left < right


通过不断缩小范围,最终能够找到数组的最小值


2512850ada2d425db1108dafeb2ca822.png


完整代码

publicclassSolution {
publicintminNumberInRotateArray(int[] nums) {
if(nums.length==0){
return-1;
        }
intleft=0;
intright=nums.length-1;
while(left<right){
//找到数组的中点intmid= (left+right) /2;
if(nums[mid] >nums[right]){
//旋转点在[mid+1, j]中,跳过mid+1左边元素left=mid+1;
            } elseif(nums[mid] <nums[right]){
//旋转点在[left, mid]中,跳过mid右边元素right=mid;
            }else{
//缩小right继续查找right--;
            }
        }
//返回旋转点returnnums[left];
    }
}


注:题目出自牛客网,链接如下


https://www.nowcoder.com/practice/9f3231a991af4f55b95579b44b7a01ba?tpId=13&tqId=23269&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

目录
相关文章
|
2月前
|
存储 缓存 算法
Java 数组
【10月更文挑战第19天】Java 数组是一种非常实用的数据结构,它为我们提供了一种简单而有效的方式来存储和管理数据。通过合理地使用数组,我们能够提高程序的运行效率和代码的可读性。更加深入地了解和掌握 Java 数组的特性和应用,为我们的编程之旅增添更多的精彩。
33 4
|
2月前
|
存储 缓存 算法
提高 Java 数组性能的方法
【10月更文挑战第19天】深入探讨了提高 Java 数组性能的多种方法。通过合理运用这些策略,我们可以在处理数组时获得更好的性能表现,提升程序的运行效率。
40 2
|
2月前
|
存储 Java
Java“(array) <X> Not Initialized” (数组未初始化)错误解决
在Java中,遇到“(array) &lt;X&gt; Not Initialized”(数组未初始化)错误时,表示数组变量已被声明但尚未初始化。解决方法是在使用数组之前,通过指定数组的大小和类型来初始化数组,例如:`int[] arr = new int[5];` 或 `String[] strArr = new String[10];`。
95 2
|
2月前
|
存储 Java
什么是带有示例的 Java 中的交错数组?
什么是带有示例的 Java 中的交错数组?
53 9
|
2月前
|
Java
Java数组动态扩容和动态缩减
Java数组动态扩容和动态缩减
26 3
|
2月前
|
存储 算法 Java
Java一分钟之-数组的创建与遍历
数组作为Java中存储和操作一组相同类型数据的基本结构,其创建和遍历是编程基础中的基础。通过不同的创建方式,可以根据实际需求灵活地初始化数组。而选择合适的遍历方法,则可以提高代码的可读性和效率。掌握这些基本技能,对于深入学习Java乃至其他编程语言的数据结构和算法都是至关重要的。
30 6
|
2月前
|
存储 Java 程序员
【一步一步了解Java系列】:何为数组,何为引用类型
【一步一步了解Java系列】:何为数组,何为引用类型
34 1
|
2月前
|
存储 XML Java
如何在 Java 中将常见文档转换为 PNG 图像数组
如何在 Java 中将常见文档转换为 PNG 图像数组
18 1
|
2月前
|
存储 安全 Java
Java数组(Arrays)详解
Java 中的数组是一种用于存储固定数量同类型数据的高效数据结构,支持连续内存存储和随机访问。数组可以声明并初始化,通过索引访问和修改元素,获取长度,使用循环遍历,支持多维形式,并可通过 `Arrays` 类的方法进行复制和排序。数组具有固定大小和类型安全的特点,但需注意越界等问题。灵活运用数组能显著提升编程效率。
125 9
|
3月前
|
存储 Java 数据处理
Java 数组的高级用法
在 Java 中,数组不仅可以存储同类型的数据,还支持多种高级用法,如多维数组(常用于矩阵)、动态创建数组、克隆数组、使用 `java.util.Arrays` 进行排序和搜索、与集合相互转换、增强 for 循环遍历、匿名数组传递以及利用 `Arrays.equals()` 比较数组内容。这些技巧能提升代码的灵活性和可读性,适用于更复杂的数据处理场景。
42 10