码迷,mamicode.com
首页 > 其他好文 > 详细

乘风破浪:LeetCode真题_035_Search Insert Position

时间:2019-01-05 15:15:52      阅读:157      评论:0      收藏:0      [点我收藏+]

标签:pos   image   二分查找算法   tar   位置   很多   ==   center   问题   

乘风破浪:LeetCode真题_035_Search Insert Position

一、前言

    这次的问题比较简单,也没有限制时间复杂度,但是要注意一些细节上的问题。

二、Search Insert Position

2.1 问题

技术分享图片

技术分享图片

2.2 分析与解决

    同样也可以使用二分查找和直接查找。

public class Solution {
    /**
     * <pre>
     * 原题
     * [1,3,5,6], 5 → 2
     * [1,3,5,6], 2 → 1
     * [1,3,5,6], 7 → 4
     * [1,3,5,6], 0 → 0
     *
     * 题目大意
     * 给定一个排序数组,和一个指定的值,如果找到这个值,返回这个值位置,如果没有找到,返回这个值在数组中的插入位置。
     * 假设数组中没有重复的元素。
     *
     * 解题思路
     * 一、最直接的查找算法,从左向右搜索。
     * 二、使用二分查找算法。
     */
    public int searchInsert(int[] A, int target) {

        int mid;
        int lo = 0;
        int hi = A.length - 1;

        while (lo <= hi) {
            //注意这里的等于,就是为了查找不中返回lo方便
            mid = lo + (hi - lo) / 2;

            if (A[mid] == target) {
                return mid;
            } else if (A[mid] < target) {
                lo = mid + 1;
            } else {
                hi = mid - 1;
            }
        }

        return lo;
    }

    public int searchInsert2(int[] A, int target) {

        if (A == null) {
            return -1;
        }

        int i;
        for (i = 0; i < A.length; i++) {
            if (A[i] >= target) {
                return i;
            }
        }

        return i;
    }
}

 技术分享图片

三、总结

    很多东西我们反复的练习就是为了能够打开自己的思维,从而推陈出新。

乘风破浪:LeetCode真题_035_Search Insert Position

标签:pos   image   二分查找算法   tar   位置   很多   ==   center   问题   

原文地址:https://www.cnblogs.com/zyrblog/p/10224327.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!