溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

java計算買賣股票的示例分析

發(fā)布時間:2021-08-11 11:26:25 來源:億速云 閱讀:158 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“java計算買賣股票的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“java計算買賣股票的示例分析”這篇文章吧。

問題:

java計算買賣股票的示例分析

可以將問題轉(zhuǎn)化為如下圖所示,即求多個累計的收入差

java計算買賣股票的示例分析

分析:

如果當(dāng)前位置i的價格比i+1的價格高,則當(dāng)前不是買入點(diǎn),則繼續(xù)判斷下一個位置,

如果當(dāng)前位置i的價格比i+1的價格低,并且i+1仍比i+1+1低,則在當(dāng)前位置買入,知道i+n比i+n+1大時,賣出。

繼續(xù)下一輪判斷

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) {
      //找到賣出點(diǎn),谷底
      while (cur < prices.length - 1 && prices[cur] >= prices[cur + 1]) {
        cur++;
      }
      vally = prices[cur];
      //找到比當(dāng)前大的值(即最高點(diǎn),頂峰)
      while (cur < prices.length - 1 && prices[cur] <= prices[cur + 1]) {
        cur++;
      }
      peak = prices[cur];
      income += peak - vally;
      //如果此時cur仍然沒有到最后,則進(jìn)行再一次循環(huán)
    }
    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計算買賣股票的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI