2021-01-15

科二是sb下次必过

Java实现Leetcode23、题

23.合并K个升序链表

题目描述

给你一个链表数组,每个链表都已经按升序排列。
请你将所有链表合并到一个升序链表中,返回合并后的链表。

示例 1:
输入:lists = [[1,4,5],[1,3,4],[2,6]]
输出:[1,1,2,3,4,4,5,6]
解释:链表数组如下:
[
1->4->5,
1->3->4,
2->6
]
将它们合并到一个有序链表中得到。
1->1->2->3->4->4->5->6

示例 2:
输入:lists = []
输出:[]

示例 3:
输入:lists = [[]]
输出:[]

思路

参考21题合并两个有序链表,可以将K个链表前两个先合并再合并第三个直到最后一个。合并两个链表时封装函数,新建一个链表,比较待合并的两个链表的头节点值,将val小的添加到新链表tail.next。

代码
class Solution {
    
    
    public ListNode mergeKLists(ListNode[] lists) {
    
    
        ListNode ans=null;
        for(int i=0;i<lists.length;i++){
    
    
            ans=mergeTwo(ans,lists[i]);
        }
        return ans;
    }
    public ListNode mergeTwo(ListNode a,ListNode b){
    
    
        if(a==null||b==null){
    
    
            return a!=null?a:b;
        }
        ListNode head=new ListNode(0);
        ListNode tail=head,aP=a,bP=b;
        while(aP!=null&&bP!=null){
    
    
            if(aP.val<bP.val){
    
    
                tail.next=aP;
                aP=aP.next;
            }else{
    
    
                tail.next=bP;
                bP=bP.next;
            }
            tail=tail.next;
        }
        tail.next=(aP!=null?aP:bP);
        return head.next;
    }
}

26.删除排序数组中的重复项

题目描述

给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。

示例 1:
给定数组 nums = [1,1,2],
函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。
你不需要考虑数组中超出新长度后面的元素。

示例 2:
给定 nums = [0,0,1,1,1,2,2,3,3,4],
函数应该返回新的长度 5, 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4。

你不需要考虑数组中超出新长度后面的元素。

思路

利用指针j向i后面判断,若相同则j向后移动直至不相同时把j赋值给i

代码
class Solution {
    
    
    public int removeDuplicates(int[] nums) {
    
    
        if(nums.length==0){
    
    
            return 0;
        }
        int i=0;
        int j;
        for(j=i;j<nums.length;j++){
    
    
                if(nums[i]!=nums[j]){
    
    
                    i++;
                    nums[i]=nums[j];
                }
        }
        return i+1;
    }
}

33.搜索旋转排序数组

题目描述

升序排列的整数数组 nums 在预先未知的某个点上进行了旋转(例如, [0,1,2,4,5,6,7] 经旋转后可能变为 [4,5,6,7,0,1,2] )。
请你在数组中搜索 target ,如果数组中存在这个目标值,则返回它的索引,否则返回 -1 。

示例 1:
输入:nums = [4,5,6,7,0,1,2], target = 0
输出:4

示例 2:
输入:nums = [4,5,6,7,0,1,2], target = 3
输出:-1

示例 3:
输入:nums = [1], target = 0
输出:-1

思路

太蠢了我是傻逼,只会一个一个比过去,结果出来时间0ms

代码
class Solution {
    
    
    public int search(int[] nums, int target) {
    
    
            int j=0;
            while(j<nums.length&&target!=nums[j]){
    
    
                j++;
            }
            if(j==nums.length){
    
    
                return -1;
            }else{
    
    
                return j;
            }
    }
}

猜你喜欢

转载自blog.csdn.net/qq_45847565/article/details/112664568