首页 > 编程语言 >力扣 (LeetCode)算法入门——Day1

力扣 (LeetCode)算法入门——Day1

时间:2022-10-22 20:22:22浏览次数:81  
标签:right target int Day1 力扣 low 版本 LeetCode left

704. 二分查找

题目:给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target  ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。

class Solution {
    public int search(int[] nums, int target) {
         int low=0;//数组的第一位
         int high=nums.length-1;//数组的第二位
        while(low<=high){
            int mid=(high-low)/2+low;//用于查找数组的中间值
            int num=nums[mid];//储存中间值
            if(num==target)
                return mid;
            else if (num>target)
                high=mid-1;
            else
                low=mid+1;
        }
        return -1;//不存在时返回-1
    }
}

278. 第一个错误的版本

题目:

你是产品经理,目前正在带领一个团队开发新的产品。不幸的是,你的产品的最新版本没有通过质量检测。由于每个版本都是基于之前的版本开发的,所以错误的版本之后的所有版本都是错的。

假设你有 n 个版本 [1, 2, ..., n],你想找出导致之后所有版本出错的第一个错误的版本。

你可以通过调用 bool isBadVersion(version) 接口来判断版本号 version 是否在单元测试中出错。实现一个函数来查找第一个错误的版本。你应该尽量减少对调用 API 的次数。

/* The isBadVersion API is defined in the parent class VersionControl.
      boolean isBadVersion(int version); */

public class Solution extends VersionControl {
    public int firstBadVersion(int n) {
        int left=1;
        int right=n;
        while (left<right){
            int mid=left+(right-left)/2;
            if (isBadVersion(mid))
                right=mid;
            else
                left=mid+1;
        }
        return left;
    }
}

35. 搜索插入位置

题目:

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。

请必须使用时间复杂度为 O(log n) 的算法。

class Solution {
    public int searchInsert(int[] nums, int target) {
        int low=0;
        int high=nums.length-1;
        while(low<=high){
            int mid=(high-low)/2+low;
            if(nums[mid]==target)//判断中间值是否为给定值
                return mid;
            else if(nums[mid]>target)
                high=mid-1;
            else
                low=mid+1;
        }
        return low;
        //当查询不到时返回low
        //因为前面的if条件,low的值始终比给定值小,即low为按顺序插入的位置
        //引用https://leetcode.cn/u/munpf/的话
        /*ans变量,最后直接返回left就可以了,根据if的判断条件,left左边的值一直保持小于target,
        right右边的值一直保持大于等于target,而且left最终一定等于right+1,这么一来,循环结束后,
        在left和right之间画一条竖线,恰好可以把数组分为两部分:left左边的部分和right右边的部分,
        而且left左边的部分全部小于target,并以right结尾;right右边的部分全部大于等于target,
        并以left为首。所以最终答案一定在left的位置*/
    }
}

 

标签:right,target,int,Day1,力扣,low,版本,LeetCode,left
From: https://www.cnblogs.com/huajianyizou/p/16817211.html

相关文章

  • leetcode(30)单调栈
    6077.巫师的总力量和注意:因为要求连续,所以不能用回溯的方法做496.下一个更大元素I子数组的最小值之和子数组最小乘积的最大值子数组范围和901.股票价格跨度用......
  • day1.1
    Markdown二级三级标题字体粗体斜体粗斜删除引用我要活分割线图片![图片](pic.cnblogs.com/avatar/2774129/20220902225016.png)超链接[点击跳转百度](www......
  • #yyds干货盘点# LeetCode 腾讯精选练习 50 题:字符串转换整数 (atoi)
    题目:请你来实现一个 myAtoi(strings) 函数,使其能将字符串转换成一个32位有符号整数(类似C/C++中的atoi函数)。函数 myAtoi(strings)的算法如下:读入字符串并丢弃无......
  • #yyds干货盘点# LeetCode 腾讯精选练习 50 题: 回文数
    题目:给你一个整数x,如果x是一个回文整数,返回true;否则,返回false。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。例如,121是回文,而123不是。 示例1:输入......
  • #yyds干货盘点# LeetCode 腾讯精选练习 50 题:整数反转
    题目:给你一个32位的有符号整数x,返回将x中的数字部分反转后的结果。如果反转后整数超过32位的有符号整数的范围 [−231, 231 −1],就返回0。假设环境不允许存......
  • 【LeetCode 904-medium】水果成篮
    1、 这题做法多种多样,看能不能找到五种做法。 其实就是这道题:​ 力扣题我的AC代码:(法1:边遍历边维护答案,如果遇到f[i]是第三个数就抛弃除了f[i-1]的另一个数)classSolutio......
  • 刷题 LeetCode 栈和队列2
    代码随想录LeetCode20. 有效的括号carl栈思路左括号入栈,右括号出栈,如果出栈时栈为空或不匹配,或者最终栈不为空则false细节LeetCode1047. 删除字符串中的所有......
  • 《剑指offer》day17
    最小的k个数题目描述思路快速排序注意本题对返回结果的顺序性没有要求,可以根据基准点来提高效率当基准点==k,直接返回当基准点>k,往左递归否则往右递归代码实现c......
  • 【算法训练营day11】LeetCode20. 有效的括号 LeetCode1047. 删除字符串中的所有相邻重
    【算法训练营day11】LeetCode20.有效的括号LeetCode1047.删除字符串中的所有相邻重复项LeetCode150.逆波兰表达式求值LeetCode20.有效的括号题目链接:20.有效的括......
  • 力扣1235(java)-规划兼职工作(困难)
    题目:你打算利用空闲时间来做兼职工作赚些零花钱。这里有 n 份兼职工作,每份工作预计从 startTime[i] 开始到 endTime[i] 结束,报酬为 profit[i]。给你一份兼职工作......