题解 | #旋转位置的特定牛# java

旋转位置的特定牛

https://www.nowcoder.com/practice/4872ba1fef224bd382b49a5958d996ab

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param nums int整型一维数组
     * @param target int整型
     * @return int整型
     */
    public int search (int[] nums, int target) {
        // write code here
        int left = 0, right = nums.length - 1;
        while (left <= right) {
            int mid = left + (right - left) / 2;
            if (nums[mid] == target) {
                return mid;
            }
            if (nums[mid] <= nums[left]) {
                if (target <= nums[left] && target > nums[mid]) {
                    right = mid - 1;
                } else {
                    left = mid + 1;
                }
            } else {
                if (target < nums[mid] && target >= nums[right]) {
                    left = mid + 1;
                } else {
                    right = mid - 1;
                }
            }
        }
        return -1;
    }
}

编程语言是Java。

该题考察的知识点是二分查找。

代码的文字解释如下:

  1. left和right,分别表示查找范围的左边界和右边界,初始值分别为0和nums数组的长度减1。
  2. 二分查找,当左边界小于等于右边界时继续查找:计算中间位置mid = left + (right - left) / 2。如果中间位置的元素等于目标值target,则返回中间位置mid。如果中间位置的元素小于等于左边界位置的元素,表示mid及其左边是一个递减区间:如果目标值在[left, mid]范围内,将右边界更新为mid - 1,即在左侧递减区间中进行查找。否则,将左边界更新为mid + 1,即在右侧进行查找。如果中间位置的元素大于左边界位置的元素,表示左侧是一个递增区间:如果目标值在(mid, right]范围内,将左边界更新为mid + 1,即在右侧递增区间中进行查找。否则,将右边界更新为mid - 1,即在左侧进行查找。
  3. 如果未找到目标值,则返回-1。
全部评论

相关推荐

Wy_m:只要不是能叫的上名的公司 去实习没有任何意义 不如好好沉淀自己
点赞 评论 收藏
分享
烤点老白薯:这种东西到时候公众号搜索都有的
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务