码迷,mamicode.com
首页 > 其他好文 > 详细

买卖股票的最佳时机II

时间:2020-02-27 21:07:30      阅读:65      评论:0      收藏:0      [点我收藏+]

标签:最大利润   算法   lse   class   UNC   tick   ack   highlight   注意   

package main

import "fmt"

func main() {

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

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

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

	示例 3:
	输入: [7,6,4,3,1]
	输出: 0
	解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。
	*/

	/*
	任意一天买入,之后的任意一天卖出
	之后还可以买入和卖出
	*/

	slice := []int{7, 1, 5, 3, 6, 4}
	ticket(slice)

}

func ticket(s []int) {
	for i := 0; i < len(s); i++ {
		//买入
		buy := s[i]
		//卖出
		if len(s[i+1:]) == 0 {
			//利润
			num := - buy
			fmt.Println("利润:", num)
		} else {
			for j := 0; j < len(s[i+1:]); j++ {
				sell := s[i+1:][j]
				//利润
				num := sell - buy
				fmt.Println("利润:", num)
				//继续买入和卖出
				newslice := s[i+1:][j+1:]
				ticket(newslice)
			}
			
		}

	}

}

//有待完善!!!

  

买卖股票的最佳时机II

标签:最大利润   算法   lse   class   UNC   tick   ack   highlight   注意   

原文地址:https://www.cnblogs.com/yzg-14/p/12374112.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!