信息學奧賽一本通【1302】股票買賣

来源:https://www.cnblogs.com/xwf2005/archive/2023/12/05/17877940.html
-Advertisement-
Play Games

信息學奧賽一本通1302 1302:股票買賣 時間限制: 1000 ms 記憶體限制: 65536 KB 【題目描述】 最近越來越多的人都投身股市,阿福也有點心動了。謹記著“股市有風險,入市需謹慎”,阿福決定先來研究一下簡化版的股票買賣問題。 假設阿福已經準確預測出了某隻股票在未來N天的價格,他希望買 ...


信息學奧賽一本通1302

1302:股票買賣 時間限制: 1000 ms 記憶體限制: 65536 KB

 

【題目描述】

最近越來越多的人都投身股市,阿福也有點心動了。謹記著“股市有風險,入市需謹慎”,阿福決定先來研究一下簡化版的股票買賣問題。 假設阿福已經準確預測出了某隻股票在未來N天的價格,他希望買賣兩次,使得獲得的利潤最高。為了計算簡單起見,利潤的計算方式為賣出的價格減去買入的價格。 同一天可以進行多次買賣。但是在第一次買入之後,必須要先賣出,然後才可以第二次買入。 現在,阿福想知道他最多可以獲得多少利潤。

 

 

【輸入】

輸入的第一行是一個整數T(T≤50),表示一共有T組數據。 接下來的每組數據,第一行是一個整數N(1≤N≤100,000),表示一共有N天。第二行是 N 個被空格分開的整數,表示每天該股票的價格。該股票每天的價格的絕對值均不會超過1,000,000。

 

【輸出】

對於每組數據,輸出一行。該行包含一個整數,表示阿福能夠獲得的最大的利潤。

 

 

【輸入樣例】 .

3 7 5 14 -2 4 9 3 17 6 6 8 7 4 1 -2 4 18 9 5 2

 

【輸出樣例】

28 2 0 解決思路 對於這道題,明顯每一天的最大利潤與之前的日子的利潤有關,而與後面的利潤無關。所以此該題符合無後效性原則,且每天的利潤可由前一天的狀態更新出來,那麼該題可用動態規劃的思路解決。

 

 

【數組定義】:

設置函數f[i][j][k]數組用於存儲dp的結果,即到第i天,進行第j次交易,狀態為k時的總利潤。i代表第幾天,j代表第幾次交易,對於k,k=0時代表這一天不持有股票,k=1時代表這一天持有股票。 data[]存放每天的股票的價值

 

【狀態轉移】

對於f[i][j][0],意味著此時不持有股票,那麼今天不擁有股票,可能是因為前一天不擁有,那麼到目前為止的總利潤不變。也可能是前一天擁有股票,但是今天賣出了,此時也收穫了大小為data[i]的利益而。f[i][j][1]應取這兩種情況的最大值。用代碼表示就是:

f[i][j][0]=max(f[i][j][0],f[i][j][1]+data[i]);

 

對於f[i][j][1],意味著目前具有股票,當前具有股票,可能是因為上一天的股票保留到了今天,利潤不變。也可能是因為前一天本來沒有股票,今天購入了股票,利潤減少data[i]。而f[i][j][1]應取這兩種情況的最大值。用代碼表示就是:

f[i][j][1]=max(f[i][j-1][0]-data[i],f[i][j][1]);

 

【代碼示例】

 1 #include <bits/stdc++.h> 
using namespace std; 2 3 int data[100005],f[3][3]; 4 5 int max(int a,int b) { 6 return a>b?a:b; 7 } 8 9 int min(int a,int b) { 10 return a<b?a:b; 11 } 12 13 int main() { 14 int t,n; 15 cin>>t; 16 while(t--) { 17 18 memset(f,0,sizeof(f)); 19 cin>>n; //三個維度的意義為:第幾天,第幾次交易,手中是否持有股票 20 f[0][0]=0; 21 f[0][1]=-1e8; 22 f[1][1]=-1e8; 23 f[1][0]=0; 24 f[2][1]=-1e8; 25 for(int i=1; i<=n; i++) { 26 scanf("%d",&data[i]); 27 } 28 for(int i=1; i<=n; i++) { 29 for(int j=1; j<=2; j++) { 30 f[i][j][0]=max(f[i][j][0],f[i][j][1]+data[i]); 31 f[i][j][1]=max(f[i][j-1][0]-data[i],f[i][j][1]); 32 } 33 } 34 printf("%d\n",f[n][2][0]); 35 }

 

【空間優化】 我們發現f[i]都是由f[i-1]更新得到的,所以我們可以不用設置[i]這一維度,我們只需要從上一次記錄的結果再進行更新就好了,代碼如下

 1 #include <iostream>
 2 using namespace std;
 3 
 4 int data[100005],f1[100005],f2[100005];
 5 int mmin=1e7,mmax=-1e7;
 6 
 7 int max(int a,int b){
 8     return a>b?a:b; 
 9 }
10 
11 int min(int a,int b){
12     return a<b?a:b; 
13 }
14 
15 int main(){
16     int t ;
17     cin>> t ;
18     while(t--){
19         int n,ans=0;
20         cin>>n;
21         for(int i=1;i<=n;i++){
22             scanf("%d",&data[i]);
23         }
24         mmin=1e7,mmax=-1e7;
25         for(int i=2;i<=n;i++)
26         {
27             mmin=min(mmin,data[i]);
28             f1[i]=max(f1[i-1],data[i]-mmin);
29         }
30         f2[n+1]=0;
31         mmin=1e7,mmax=-1e7;
32         for(int i=n-1;i>=1;i--)
33         {
34             mmax=max(mmax,data[i]);
35             f2[i]=max(f2[i+1],mmax-data[i]);
36 
37         }
38         for(int i=1;i<n;i++){
39             ans=max(ans,f1[i]+f2[i+1]);
40         }
41         printf("%d\n",ans);
42     }
43     return 0;
44 }

 PS:個人日常發佈學習筆記,本篇思路從【董曉老師】處學習

董曉老師博客:https://www.cnblogs.com/dx123/ 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 項目代碼同步至碼雲 weiz-vue3-template pina 是 vue3 官方推薦的狀態管理庫,由 Vue 核心團隊維護,旨在替代 vuex。pina 的更多介紹,可從 pina官網 查看 特點 更簡潔直接的 API,提供組合式風格的 API 支持模塊熱更新和服務端渲染 對TS支持更為友好 ...
  • 一、CSS簡介 CSS:層疊樣式表(英文全稱:Cascading Style Sheets):是一種用來表現HTML樣式的電腦語言。CSS不僅可以靜態地修飾網頁,還可以配合各種腳本語言動態地對網頁各元素進行格式化。 二、CSS選擇器 2.1基本選擇器(三種) 1.標簽選擇器 <style> p { ...
  • 前言 這是第三次博客作業,總結了近三次PTA大作業的完成情況,作業7、8次的大作業的小題目圍繞著HashMap、ArrayList和自定義介面來展開,大題目則是課程成績程式的第二次第三次迭代,因為第一次課程成績的程式寫的結構不太好,於是重新寫的,第三次迭代並沒有拿到滿分,後面也沒有時間改了。期末考試 ...
  • 2.7Python(目前ArcGIS使用)代碼轉化為3.5Python(目前ArcGIS Pro使用)代碼 Analyze Tools For Pro (2to3命令) 基本操作 調用ArcToolbox的兩種形式 #arcpy.ToolboxAlias.ToolName() #arcpy.Tool ...
  • Java作為最熱門的開發語言之一,長居各類排行榜的前三。所以,就算你目前不是用Java開發,你應該瞭解Java語言的特點,能用來做什麼,以備不時之需。 Java 是一種高級、多範式編程語言,以其編譯為獨立於平臺的位元組碼的能力而聞名。 它是由 Sun Microsystems 的 James Gosl ...
  • 外接矩形、外接圓: 1 import cv2 2 import numpy 3 4 img = cv2.imread('../img/img.png', -1) 5 ret, thresh = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY) 6 con ...
  • 這份筆記詳細介紹了Spring MVC中的關鍵概念。在Ajax集成部分,通過引入相關依賴和開發控制器,展示瞭如何以JSON格式返回數據。特別強調了日期格式修正,使用@JsonFormat註解來規範日期顯示。 攔截器章節深入探討了攔截器的作用、特點和開發過程。與AOP進行對比,並解釋了其在請求處理階段... ...
  • SSM框架中各層次作用及其關係(二) 在SSM框架(Spring + Spring MVC + MyBatis)中,各層次分工協作,形成了一種分層架構,有助於提高代碼的可維護性和可擴展性。以下是SSM框架中各層次的作用及其關係: 表現層(Presentation Layer): 使用Spring M ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...