首页 > 编程语言 >Java常用的算法

Java常用的算法

时间:2023-04-11 10:58:07浏览次数:48  
标签:常用 Java target nums int mid high 算法 low

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

class Solution {
    public int search(int[] nums, int target) {
    int low = 0,high = nums.length-1;
    while(low <= high) {
            int mid = (low + high)/2;
            if(nums[mid] == target){
                return mid;
            } else if(target > nums[mid]) {
                low = mid+1;
            } else if(nums[target < nums[mid]) {
                high = mid -1;
            }
        }
        return -1;
    }
}

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

假设你有 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 low = 1,high = n;
        while(low < high) {
            int mid = (high - low)/2+low;
            if(isBadVersion(mid)){
                high = mid;
            } else {
                low = mid +1;
            }
        }
        return high;
    }
}

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

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

class Solution {
    public int searchInsert(int[] nums, int target) {
        int low = 0,high = nums.length-1;
        while(low <= high) {
            int mid = (high+low)/2;
            if(nums[mid] == target) {
                return mid;
            }else if (target > nums[mid]) {
                low = mid +1;
            } else if(target < nums[mid]) {
                high = mid -1;
            }
        }
        return low;
    }
}

4.给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。

示例 1:

输入:nums = [-4,-1,0,3,10]
输出:[0,1,9,16,100]
解释:平方后,数组变为 [16,1,0,9,100]
排序后,数组变为 [0,1,9,16,100]

class Solution {
    public int[] sortedSquares(int[] nums) {
        int[] nums1 = new int[nums.length];
        for(int i = 0, j = nums.length-1, pos = nums.length -1; i<=j;) {
            if (nums[i]*nums[i] > nums[j]*nums[j]){
                nums1[pos] = nums[i]*nums[i];
                ++i;
            }else {
                nums1[pos] = nums[j]*nums[j];
                --j;
            }
            --pos;
        }
        return nums1;
    }
}

 

标签:常用,Java,target,nums,int,mid,high,算法,low
From: https://www.cnblogs.com/wk-missQ1/p/17305446.html

相关文章

  • java大数加法的一种思路
    packageorg.example;importjava.util.ArrayList;importjava.util.List;importjava.util.Scanner;classSuperNum{publicList<Integer>numList;/***成员变量的set方法*@paramnumList*/publicvoidsetNumList(List<Inte......
  • 常用命令--ADB
    ADB全程:AndroidDebugBridge,常用的androiddebug工具。 1.查看当前的连接设备:adbdevices2.进入到设备:adbshell进入之后使用shell命令,cd、ls,rm等。3.设备有多个,需要指定其中一个设备:adb-s设备名shell4.打开或重启adbadbstart-serveradbreboot5.关闭adb......
  • SpringBoot线程池和Java线程池的实现原理
    使用默认的线程池方式一:通过@Async注解调用publicclassAsyncTest{@Asyncpublicvoidasync(Stringname)throwsInterruptedException{System.out.println("async"+name+""+Thread.currentThread().getName());Thread.sleep(10......
  • JavaScript 去除数组中重复的元素 得到新数组
    方法一:思路:准备一个新数组,将原数组中的元素一一放入新数组,放入之前判断该元素是否存在新数组中,不存在的话就直接存入新数组。functionuniqueArr(arr){ varnewArr=[]; for(leti=0;i<arr.length;i++){ if(newArr.indexOf(arr[i])==-1){ newArr.push(arr[i]); } } r......
  • Javascript 原型与原型链
    在BrendanEich设计Javascript时,借鉴了Self和Smalltalk这两门基于原型的语言。之所以选择基于原型的面向对象系统,是因为BrendanEich一开始没有打算在JavaScript中加入类的概念,其设计初衷是为非专业的开发人员提供一个方便的工具,使其使用尽可能简单、易学。随着人们对网页要求的逐......
  • java包装类
    基本数据类型包装类byteBytebooleanBooleanshortShortcharCharacterintIntegerlongLongfloatFloatdoubleDouble/*Integeri=100;intj=newInteger(100); 自动装箱调用的是valueOf()方法,而不是newInteger()方......
  • java jar包运行用外置配置yml文件
    1.准备文件和目录2.启动命令java-jar-Dspring.config.location=config/application.ymldatachangenew.jar ......
  • delphi 11.3 java.ioexception:cleartext http traffic [IP地址] not permitted
    要在AndroidManifest.xml添加如下属性即可:参考:HowtoFixCleartextHTTPTrafficnotPermittedinAndroid-TRENDOCEANS ......
  • 用Java写一段中国身份证的正则表达式,要求验证身份证中的日期,且大于1900年,以及校验码验
    以下是一个Java正则表达式,可用于验证中国身份证中的日期,并要求日期在1900年及之后:Stringregex="(?:(?:19[0-9]\\d)|(?:[2-9]\\d{3}))(?:0[1-9]|1[012])(?:0[1-9]|[12]\\d|3[01])\\d{3}[\\dXx]";这个正则表达式的含义如下:(?:(?:19[0-9]\\d)|(?:[2-9]\\d{3})):匹配1900年......
  • 算法基础 第二章 数据结构目录
    目录静态单链表知识点模板题目单链表题目描述思路代码静态双链表知识点模板题目双链表模板题题目描述思路代码数组模拟栈知识点模板题目模拟栈题目描述思路代码数组模拟队列知识点模板题目模拟队列题目描述思路代码单调栈知识点模板题目单调栈例题题目描述思路代码单调队列知识点......