您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“java計算買賣股票的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“java計算買賣股票的示例分析”這篇文章吧。
問題:
可以將問題轉化為如下圖所示,即求多個累計的收入差
分析:
如果當前位置i的價格比i+1的價格高,則當前不是買入點,則繼續判斷下一個位置,
如果當前位置i的價格比i+1的價格低,并且i+1仍比i+1+1低,則在當前位置買入,知道i+n比i+n+1大時,賣出。
繼續下一輪判斷
package com.example.demo; public class Test121 { /** * 多個 * * @param prices * @return */ public int maxProfit(int[] prices) { if (prices == null || prices.length == 0) { return 0; } int cur = 0; int vally = prices[0]; int peak = 0; int income = 0; while (cur < prices.length - 1) { //找到賣出點,谷底 while (cur < prices.length - 1 && prices[cur] >= prices[cur + 1]) { cur++; } vally = prices[cur]; //找到比當前大的值(即最高點,頂峰) while (cur < prices.length - 1 && prices[cur] <= prices[cur + 1]) { cur++; } peak = prices[cur]; income += peak - vally; //如果此時cur仍然沒有到最后,則進行再一次循環 } return income; } public static void main(String[] args) { Test121 t = new Test121(); int[] arr = {7, 1, 5, 3, 6, 4}; int i = t.maxProfit(arr); System.out.println(i); } }
以上是“java計算買賣股票的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。