Leetcode 第121,122,136,141,144,145,155,160,167,168题(Java解法)

本文介绍了LeetCode中10道经典的算法题目,包括买卖股票的最佳时机、只出现一次的数字、环形链表、二叉树的前/后序遍历、最小栈、相交链表、两数之和II、Excel表列名称等,提供了详细的解题思路和Java代码实现。每道题目的解决方案均具有高效的时空复杂度。
摘要由CSDN通过智能技术生成

第121题 买卖股票的最佳时机

给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。
你只能选择某一天买入这只股票,并选择在未来的某一个不同的日子卖出该股票。设计一个算法来计算你所能获取的最大利润。
返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0 。

示例 1:

输入 输出
[7,1,5,3,6,4] 5

解释:在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。
注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格;同时,你不能在买入前卖出股票。

示例 2:

输入 输出
prices = [7,6,4,3,1] 0

解释:在这种情况下, 没有交易完成, 所以最大利润为 0。

解题思路

直接遍历数组,定义一个最小买入价格和一个最大收益,遍历数组时,如果最小买入价格比当前价格大,则更新最小买入价格。最大收益为当前价格减去买入价格,不断遍历更新最大值。

代码

// 买卖股票的最佳时机:
public class Solution {
   
    public int maxProfit(int prices[]) {
   
        int minprice = Integer.MAX_VALUE;
        int maxprofit = 0;//定义最大收益
        for (int i = 0; i < prices.length; i++) {
   //遍历数组
            if (prices[i] < minprice) {
   
                minprice = prices[i];//当前买入价格小于最小价格时,凌最小价格等于当前价格
            } else if (prices[i] - minprice > maxprofit) {
   
                maxprofit = prices[i] - minprice;
            }//否则计算最大收益,当前价格减去最小价格如果大于最大收益,则更新最大收益
        }
        return maxprofit;
    }
}

时间复杂度为O(n),数组长度为n
空间复杂度为O(1)

第122题 买卖股票的最佳时机 II

给定一个数组 prices ,其中 prices[i] 是一支给定股票第 i 天的价格。
设计一个算法来计算你所能获取的最大利润。你可以尽可能地完成更多的交易(多次买卖一支股票)。
注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。

示例 1:

输入 输出
prices = [7,1,5,3,6,4] 7

解释: 在第 2 天(股票价格 = 1)的时候买入,在第 3 天(股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5-1 = 4 。
随后,在第 4 天(股票价格 = 3)的时候买入,在第 5 天(股票价格 = 6)的时候卖出, 这笔交易所能获得利润 = 6-3 = 3 。

示例 2:

输入 输出
prices = [1,2,3,4,5] 4

解释: 在第 1 天(股票价格 = 1)的时候买入,在第 5 天 (股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5-1 = 4 。
注意你不能在第 1 天和第 2 天接连购买股票,之后再将它们卖出。因为这样属于同时参与了多笔交易,你必须在再次购买前出售掉之前的股票。

示例 3:

输入 输出
prices = [7,6,4,3,1] 0

解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。

解题思路

使用贪心算法,设一个结果值ans,从头开始遍历数组,只要当前价格比前一天价格高,就将两者的差值加到ans上

代码

// 买卖股票的最佳时机 II:贪心算法
class Solution {
   
    public int maxProfit(int[] prices) {
   
        int ans = 0;
        int n = prices.length;
        for (int i = 1; i < n; ++i) {
   
            ans += Math.max(0, prices[i] - prices[i - 1]);//如果当前值大于前一值,则加入两者差值
        }
        return ans;
    }
}

时间复杂度为O(n),n为数组长度
空间复杂度为O(1)

第136题 只出现一次的数字

给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:
你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?

示例 1:

输入 输出
[2,2,1] 1

示例 2:

输入 输出
[4,1,2,1,2] 4

解题思路

该题使用位运算,由a⊕a=0,a⊕0=a可知,将数组所有元素执行异或操作,最后剩下的数字就是结果

代码

// 只出现一次的数字:位运算
class Solution {
   
    public int singleNumber(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值