【小Y学算法】⚡️每日LeetCode打卡⚡️——43. 两数之和 II - 输入有序数组

????前言

???? 算法题 ????

???? 每天打卡一道算法题,既是一个学习过程,又是一个分享的过程????

???? 提示:本专栏解题 编程语言一律使用 C# 和 Java 两种进行解题

???? 要保持一个每天都在学习的状态,让我们一起努力成为算法大神吧????!

???? 今天是力扣算法题持续打卡第43天????!

???? 算法题 ????

????原题样例:两数之和 II - 输入有序数组

给定一个已按照 非递减顺序排列 的整数数组 numbers ,请你从数组中找出两个数满足相加之和等于目标数 target 。


函数应该以长度为 2 的整数数组的形式返回这两个数的下标值。

numbers 的下标 从 1 开始计数 ,所以答案数组应当满足 1 <= answer[0] < answer[1] <= numbers.length 。


你可以假设每个输入 只对应唯一的答案 ,而且你 不可以 重复使用相同的元素。


示例 1:

输入:numbers = [2,7,11,15], target = 9
输出:[1,2]
解释:2 与 7 之和等于目标数 9 。因此 index1 = 1, index2 = 2 。

示例 2:

输入:numbers = [2,3,4], target = 6
输出:[1,3]

示例 3:

输入:numbers = [-1,0], target = -1
输出:[1,2]

提示:


2 <= numbers.length <= 3 * 104

-1000 <= numbers[i] <= 1000

numbers 按 非递减顺序 排列

-1000 <= target <= 1000

仅存在一个有效答案

????C#方法:深度优先搜索

既然是求解二叉树的最小深度,那我们就把二叉树整个遍历一遍然后判断深度就好了


使用深度优先搜索的方法,遍历整棵树,记录最小深度。


对于每一个非叶子节点,我们只需要分别计算其左右子树的最小叶子节点深度。


这样就将一个大问题转化为了小问题,可以递归地解决该问题。


思路解析


代码:

public class Solution {
    public int MinDepth(TreeNode root) {
         if (root == null) return 0;
        else if (root.left == null) return MinDepth(root.right) + 1;
        else if (root.right == null) return MinDepth(root.left) + 1;
        else return Math.Min(MinDepth(root.left), MinDepth(root.right)) + 1;
    }
}

执行结果

通过
执行用时:272 ms,在所有 C# 提交中击败了46.32%的用户
内存消耗:50 MB,在所有 C# 提交中击败了50.00%的用户

复杂度分析

时间复杂度:O( n ),其中 n 是树的节点数
空间复杂度:O( H ),其中 H 是树的高度
• 1
• 2

????Java 方法一:二分查找

思路解析


在数组中找到两个数,使得它们的和等于目标值,可以首先固定第一个数,然后寻找第二个数,第二个数等于目标值减去第一个数的差。


利用数组的有序性质,可以通过二分查找的方法寻找第二个数。


为了避免重复寻找,在寻找第二个数时,只在第一个数的右侧寻找。


代码:

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

执行结果

通过
执行用时:3 ms,在所有 Java  提交中击败了26.14%的用户
内存消耗:38.6 MB,在所有 Java 提交中击败了52.15%的用户

复杂度分析

时间复杂度:O( nlog n )
空间复杂度:O( 1 )

????Java 方法二:双指针

思路解析

【小Y学算法】⚡️每日LeetCode打卡⚡️——43. 两数之和 II - 输入有序数组

代码:

class Solution {
    public int[] twoSum(int[] numbers, int target) {
        int low = 0, high = numbers.length - 1;
        while (low < high) {
            int sum = numbers[low] + numbers[high];
            if (sum == target) {
                return new int[]{low + 1, high + 1};
            } else if (sum < target) {
                ++low;
            } else {
                --high;
            }
        }
        return new int[]{-1, -1};
    }
}

执行结果

通过
执行用时:0 ms,在所有 Java  提交中击败了100.00%的用户
内存消耗:38.4 MB,在所有 Java 提交中击败了85.91%的用户

复杂度分析

时间复杂度:O(n)
空间复杂度:O(1)

????总结

  • 今天是力扣算法题打卡的第四十三天!
  • 文章采用 C#Java 两种编程语言进行解题
  • 一些方法也是参考力扣大神写的,也是边学习边分享,再次感谢算法大佬们
上一篇:SAP RETAIL MM42进入商品的销售视图系统提示: No basic purchase price relevant to pricing found with schema RM0000


下一篇:Eclipse如何跳转到Java系统类的源代码