博客
关于我
L121买卖股票的最佳时机
阅读量:215 次
发布时间:2019-02-28

本文共 2672 字,大约阅读时间需要 8 分钟。

  1. 买卖股票的最佳时机
    给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。

如果你最多只允许完成一笔交易(即买入和卖出一支股票一次),设计一个算法来计算你所能获取的最大利润。

注意:你不能在买入股票前卖出股票。

示例 1:

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

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

输入: [7,6,4,3,1]

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

1.暴力方法

class Solution {       public int maxProfit(int[] prices) {           int len = prices.length;        if(len == 0) return 0;                int max = Integer.MIN_VALUE;        for(int i = 0; i < len; i++) {           	for(int j = i; j 

注意两者下标的区别,主要是怕漏了为0的结果

class Solution {       public int maxProfit(int[] prices) {           int len = prices.length;        if(len == 0) return 0;                int max = 0;//默认为0        for(int i = 0; i < len; i++) {           	for(int j = i + 1; j 

其实最小值为0未覆盖,可以使i,j重合,这样就满足最小值情况了

public int maxProfit2(int[] prices) {           //两个程序方法是相同的        int len = prices.length;        if(len  == 0) return 0;        int max = Integer.MIN_VALUE;        for(int i = 0; i < len; i++){               for(int j = i; j < len; j++){                   if(max < prices[j] - prices[i]){                       max = prices[j] - prices[i];                }            }        }        return max;    }    public int maxProfit1(int[] prices) {           int len = prices.length;        if(len == 0) return 0;        int max =Integer.MIN_VALUE;        for(int i = 0;i < len; i++){               for(int j = 0; j <= i; j++){                   if(max < prices[i] - prices[j]){                       max = prices[i] - prices[j];                }            }        }        return max;    }

2.记录最大值,利用一个变量

class Solution {       public int maxProfit(int[] prices) {           if(prices == null || prices.length == 0) return 0;        int len = prices.length;        //记录左边的最小值,一次遍历便可搞定        int minPrice = Integer.MAX_VALUE, res = 0;        for(int i = 0; i < len; i++){               if(prices[i] < minPrice) minPrice = prices[i];            if(res < prices[i] - minPrice) res = prices[i] - minPrice;        }        return res;    }}

3.动态规划

先进行状态设计
在这里插入图片描述

public int maxProfit(int[] prices) {           if(prices == null || prices.length == 0) return 0;        int len = prices.length;        if(len < 2) return 0;        int[][] dp = new int[len][2];        // dp[i][0] 下标为 i 这天结束的时候,不持股,手上拥有的现金数        // dp[i][1] 下标为 i 这天结束的时候,持股,手上拥有的现金数        dp[0][0] = 0;        dp[0][1] = -prices[0];        for(int i = 1; i < len; i++){               dp[i][0] = Math.max(dp[i - 1][0], dp[i- 1][1] + prices[i]);            dp[i][1] = Math.max(dp[i - 1][1], - prices[i]);        }        return dp[len - 1][0];        //只需要判断最后的情况即可    }

进一步压缩空间

转载地址:http://cjvp.baihongyu.com/

你可能感兴趣的文章
Nginx在Windows下载安装启动与配置前后端请求代理
查看>>
Nginx在开发中常用的基础命令
查看>>
Nginx基础知识点与使用场景梳理
查看>>
Nginx多域名,多证书,多服务配置,实用版
查看>>
nginx如何实现图片防盗链
查看>>
Nginx学习总结(10)——Nginx前后端分离将多个请求转发到多个Tomcat,负载均衡反向代理
查看>>
Nginx学习总结(11)——提高Nginx服务器的安全性,稳定性和性能的12种技巧
查看>>
Nginx学习总结(12)——Nginx各项配置总结
查看>>
Nginx学习总结(13)——Nginx 重要知识点回顾
查看>>
Nginx学习总结(14)——Nginx配置参数详细说明与整理
查看>>
Nginx学习总结(15)—— 提升 Web 应用性能的十个步骤
查看>>
Nginx学习总结(1)——Nginx入门简介
查看>>
Nginx学习总结(2)——Nginx手机版和PC电脑版网站配置
查看>>
Nginx学习总结(3)——Nginx配置及应用场景之高级配置
查看>>
Nginx学习总结(4)——负载均衡session会话保持方法
查看>>
Nginx学习总结(5)——Nginx基本配置备忘
查看>>
Nginx学习总结(6)——Nginx + https + 免费SSL证书配置指南
查看>>
Nginx学习总结(7)——Nginx配置HTTPS 服务器
查看>>
Nginx学习总结(8)——Nginx服务器详解
查看>>
Nginx学习总结(9)——前端跨域问题解决
查看>>