信息學奧賽一本通【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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...