[lintcode 14] First Position of Target
2016-08-07 22:22
351 查看
For a given sorted array (ascending order) and a
If the target number does not exist in the array, return
Example
If the array is
分析:
题中给出一个有序数组,每个元素不一定唯一,找到第一次出现target的位置。
这道题处理的关键点就是当nums[mid] == target的时候,不是将mid返回,
而是把end移动的mid点,继续向前查找看有无相同的元素。
targetnumber, find the first index of this number in
O(log n)time complexity.
If the target number does not exist in the array, return
-1.
Example
If the array is
[1, 2, 3, 3, 4, 5, 10], for given target
3, return
2.
分析:
题中给出一个有序数组,每个元素不一定唯一,找到第一次出现target的位置。
这道题处理的关键点就是当nums[mid] == target的时候,不是将mid返回,
而是把end移动的mid点,继续向前查找看有无相同的元素。
class Solution { /** * @param nums: The integer array. * @param target: Target to find. * @return: The first position of target. Position starts from 0. */ public int binarySearch(int[] nums, int target) { if (nums.length == 0) { return -1; } int start = 0, end = nums.length - 1; while (start + 1 < end) { int mid = start + (end - start) / 2; if (nums[mid] == target) { end = mid; }else if (nums[mid] < target) { start = mid; }else { end = mid; } } if (nums[start] == target) { return start; } if (nums[end] == target) { return end; } return -1; } }
相关文章推荐
- [LintCode] 14 First Position of Target
- 【简单】Lintcode 14:First Position of Target
- Lintcode 14 first position of target
- [lintcode 14] First Position of Target
- lintcode-easy-First Position of Target
- lintcode:First Position of Target
- 二分查找(first-position-of-target)
- LintCode: First Position of Target
- first-position-of-target
- Lintcode: First Position of Target (Binary Search)
- lintcode:First Position of Target
- Binary Search---First Position of Target
- First Position of Target
- First Position of Target
- #14 First Position of Target
- Lintcode14 First Position of Target Solution 题解
- last position of target / first position of target
- 简单二分法-First Position of Target
- Android error:This template requires a build target API version of at least 14, and the current vers
- lintcode(646)First Position Unique Character