`

java-69-旋转数组的最小元素。把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个排好序的数组的一个旋转,输出旋转数组的最小元素

 
阅读更多

public class MinOfShiftedArray {

	/**
	 * Q69 旋转数组的最小元素
	 * 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个排好序的数组的一个旋转,输出旋转数组的最小元素。
	 * 例如数组{3, 4, 5, 1, 2}为{1, 2, 3, 4, 5}的一个旋转,该数组的最小值为1。
	 */
	public static void main(String[] args) {
		int[][] a={
				{1,2,3,4,5},
				{2,3,4,5,1},
				{3,4,5,1,2},
				{4,5,1,2,3},
				{5,1,2,3,4},
		};
		for(int[] each:a){
			int min=minOfShiftedArray(each);
			System.out.println(min);
		}
	
		
	}

	/*
	 * Divide and conquer
	 */
	public static int minOfShiftedArray(int[] x){
		if(x==null||x.length==0){
			return -1;
		}
		int len=x.length;
		int low=0;
		int high=len-1;
		if(x[low]<x[high]){//if the array is not shifted actually,e.g. {1,2,3,4,5}
			return x[low];
		}
		int mid=0;
		while(low<high){
			mid=(low&high)+(low^high)/2;
			if(mid==low){//if there are only two elements left
				return x[low]<x[high]?x[low]:x[high];
			}
			if(x[mid]>x[low]){
				low=mid;
			}else{
				high=mid;
			}
		}
		return x[mid];
	}
}

0
0
分享到:
评论

相关推荐

    求旋转数组的最小数字(java实现)

    把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出数组的最小元素。 例如:数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1

    【剑指offer】面试题11-旋转数组的最小数字-完整的可执行代码(Java)

    把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE...

    php-leetcode题解之旋转数组.zip

    例如,一个长度为n的数组,如果我们希望将其右移k位(k小于n),则需要将数组的前n-k个元素移动到数组的末尾,然后将剩下的k个元素移动到数组的前面。 在PHP中,处理这种问题通常涉及数组的复制、索引计算和数组...

    BURmoon#CPP_notes#[数组]旋转数组的最小数字1

    题目把一个数组最开始的若干个元素搬到数组的末尾,称之为数组的旋转输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素NOTE:给出的所有元素都大于0,若数

    fengmin0722#algorithms-1#面试题11. 旋转数组的最小数字1

    面试题11. 旋转数组的最小数字把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。例如,数组 [3,4,5,1,2] 为 [1,2,3,4,5]

    java 将一个二维数组存到txt文件里,然后再读取

    ### Java将一个二维数组存到TXT文件里,然后再读取 在Java编程中,经常会遇到需要将数据存储到文件中的需求。例如,在本例中,我们需要将一个二维数组中的数据写入到TXT文件中,然后再次从该TXT文件中读取这些数据...

    js代码-200613-旋转数组的最小数字

    我们要找的是旋转后的数组中的最小元素,对于未旋转或完全旋转的数组,最小元素总是第一个元素,但对旋转数组来说,最小元素可能出现在其他位置。 解决这个问题通常有两种方法:线性搜索和二分查找。线性搜索简单但...

    将两个有序数组,合并成另一个有序的数组,升序

    当其中一个数组(这里假设是数组a)的所有元素都被放入c后,剩下的元素(来自数组b)会被直接追加到c的末尾,因为此时b数组中的元素都比a数组的剩余元素大。同样地,如果数组b先排完,那么数组a的剩余元素会追加到c...

    排序,查找,取最大值,反转-----数组.txt

    首先存储其中一个元素到临时变量中,然后将另一个元素赋值给第一个元素的位置,最后将临时变量中的值赋给第二个元素的位置。 ```java public static void swap(int[] arr, int x, int y) { int temp = arr[x]; ...

    03-python-数组方法-数组排序-数组形状-对角线

    在Python编程语言中,数组是数据处理和科学计算的核心元素。本学习笔记主要涵盖了四个关键主题:数组方法、数组排序、数组形状以及对角线操作。以下是对这些知识点的详细阐述。 **一、数组方法** Python中的数组...

    js-leetcode题解之有序数组的单个元素-题解.zip

    本题解聚焦于一个特定的LeetCode问题:如何在有序数组中找到单个出现的元素。有序数组的特点是其元素按照特定顺序排列,而单个元素指的是在数组中只出现一次的元素,其他元素可能成对出现。 JavaScript是一种广泛...

    python教程-05-数组的定义和数组的操作.ev4.rar

    3. 删除元素:`remove(element)`方法删除列表中第一个匹配的元素,`pop([index])`方法移除并返回指定索引的元素(默认为最后一个)。 4. 更新元素:直接通过索引赋值即可更新元素,如`integer_list[2] = 6`。 5. ...

    旋转数组labview源文件

    例如,你可以选择向左或向右旋转数组,即将数组的第一个元素移到末尾,第二个元素移到第一个位置,以此类推。 该.VI(Virtual Instrument)文件是LabVIEW中的程序单元,包含了用户界面(前面板)和程序逻辑(后面板...

    C++中求旋转数组中的最小数字(经典面试题)

    题目:把一个数组的最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增数组的旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1. 算法: (1)...

    旋转数组的最小数字1

    1. **旋转数组的理解**:数组的旋转意味着将数组的前 `k` 个元素移动到数组的末尾,其中 `k` 是一个非负整数,且 `0 数组长度`。旋转后,数组仍然保持单调递增的性质,只是局部顺序发生了变化。 2. **最小元素的...

    js代码-push() 向数组的末尾添加一个或更多元素,并返回新的长度。

    在JavaScript中,`push()`方法是一个非常常用的操作,它用于向数组的末尾添加一个或多个元素,并返回更新后的数组的新长度。这个方法是数组对象的内置方法,可以在任何数组上使用,无论数组是在全局作用域、函数作用...

    用数组实现的优先队列(JAVA)

    删除队首元素(即最小元素)时,将数组最后一个元素移到队首,然后通过下沉操作调整堆。 3. **PriorityQ.java文件解析** - `PriorityQ.java`文件可能包含了以下部分: - 类定义:通常会有一个名为`PriorityQ`的类...

    c++程序 数组

    c++1)一个包含10个元素的数组,已按升序排序,输入一个任意的整数, 将该整数插入数组中,使数组元素仍保持升序排列。要求编写一个通用的 插入排序函数InsertSort,它带有三个参数,第一个参数是含有n个元素的数组...

    删除数组中的元素vb6

    假设我们有一个数组`arrNumbers`,想要删除值为`targetValue`的元素: ```vb Dim arrNumbers() As Integer Dim i As Integer Dim j As Integer Dim targetValue As Integer ' 初始化数组 ReDim arrNumbers...

    2014-许智磊-后缀数组1

    可以通过计算后缀数组中每个元素与其下一个元素的LCP值来构造。许智磊提出了一种在线性时间内计算跨度为1的LCP值的算法。 后缀数组的应用: 1. 多模式串的模式匹配:后缀数组可以用来在O(m+logn)时间复杂度内完成多...

Global site tag (gtag.js) - Google Analytics