Java初阶刷题训练

文章介绍了如何使用数组排序方法(如`Arrays.sort`),二分查找算法解决LeetCode上的“搜索插入位置”和“第一坏版本”问题,以及它们在Java编程中的应用,包括面试准备和在线平台的实战练习。
摘要由CSDN通过智能技术生成

②将两个数组分别利用直接可以排序的方法进行排序,利用Array.sort()的方法进行排序

③遍历数组,来判断每个是不是对应的数据

代码如下:

class Solution {

public boolean CheckPermutation(String s1, String s2) {

boolean flag =true;

    char[] c1 = s1.toCharArray();
    char[] c2 = s2.toCharArray();
    if(c1.length!=c2.length) {
        return false;
    }

Arrays.sort(c1);

Arrays.sort(c2);

for(int i=0;i<c1.length;i++){

if(c1[i]!=c2[i]){
    return false;
}

}return true;

}

}

2.搜索插入位置


力扣icon-default.png?t=M1L8https://leetcode-cn.com/problems/search-insert-position/

题目要求及示例:

解题思路:(采用的是二分法,因为相比于直接来求,二分法可以节约一半的时间)

①题目就两种情况:a、该数存在于数组中(则直接用比其大的数的下标作为该下标进行返回)

b、该数不存在于数组中(则最后直接返回数组的长度,因为其必然插入在数组的末尾)

②分别设置left=0;right=nums.length-1;利用二分法mid进行求解即可

代码如下:

class Solution {

public int searchInsert(int[] nums, int target) {

int n = nums.length;

    int left=0,right=n-1;
    while(left<=right){
        int mid=(right+left)/2;
        if(nums[mid]<target)
            left=mid+1;
        else right=mid-1;
    }
    return left;
}

}

3.第一个错误的版本


力扣icon-default.png?t=M1L8https://leetcode-cn.com/problems/first-bad-version/

题目要求及示例:

 本题实质上是对数据进行查找

解题思路:(利用二分法的思想进行数据查找)

①分别设置left=0;right=nums.length-1;利用二分法mid进行求解即可

注意!!!

线程、数据库、算法、JVM、分布式、微服务、框架、Spring相关知识

一线互联网P7面试集锦+各种大厂面试集锦

学习笔记以及面试真题解析

img-Hv6ubv7C-1714129703185)]

一线互联网P7面试集锦+各种大厂面试集锦

[外链图片转存中…(img-L2rnENOv-1714129703185)]

学习笔记以及面试真题解析

[外链图片转存中…(img-UdysiHZC-1714129703185)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值