Java解leetcode,助力面试之简单10道题(三)
第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(