洛谷P2234 [HNOI2002]營業額統計

来源:http://www.cnblogs.com/zwfymqz/archive/2017/11/25/7896128.html
-Advertisement-
Play Games

題目描述 Tiger最近被公司升任為營業部經理,他上任後接受公司交給的第一項任務便是統計並分析公司成立以來的營業情況。 Tiger拿出了公司的賬本,賬本上記錄了公司成立以來每天的營業額。分析營業情況是一項相當複雜的工作。由於節假日,大減價或者是其他情況的時候,營業額會出現一定的波動,當然一定的波動是 ...


題目描述

Tiger最近被公司升任為營業部經理,他上任後接受公司交給的第一項任務便是統計並分析公司成立以來的營業情況。

Tiger拿出了公司的賬本,賬本上記錄了公司成立以來每天的營業額。分析營業情況是一項相當複雜的工作。由於節假日,大減價或者是其他情況的時候,營業額會出現一定的波動,當然一定的波動是能夠接受的,但是在某些時候營業額突變得很高或是很低,這就證明公司此時的經營狀況出現了問題。經濟管理學上定義了一種最小波動值來衡量這種情況:

當最小波動值越大時,就說明營業情況越不穩定。

而分析整個公司的從成立到現在營業情況是否穩定,只需要把每一天的最小波動值加起來就可以了。你的任務就是編寫一個程式幫助Tiger來計算這一個值。

第一天的最小波動值為第一天的營業額。

該天的最小波動值=min{|該天以前某一天的營業額-該天營業額|}。

輸入輸出格式

輸入格式:

 

輸入由文件’turnover.in’讀入。

第一行為正整數n(n<=32767) ,表示該公司從成立一直到現在的天數,接下來的n行每行有一個整數ai(|ai|<=1000000) ,表示第i天公司的營業額,可能存在負數。

 

輸出格式:

 

 

輸入輸出樣例

輸入樣例#1: 複製
6
5
1
2
5
4
6
輸出樣例#1: 複製
12

說明

結果說明:5+|1-5|+|2-1|+|5-5|+|4-5|+|6-5|=5+4+1+0+1+1=12

 

 

平衡樹的裸題

每次在前面找他的前驅

做差相加

 我這的這份可能是平衡樹里跑的最快的了

  1 #include<iostream>
  2 #include<cstdio>
  3 #include<cstdlib>
  4 using namespace std;
  5 const int MAXN=1e6+10;
  6 const int mod=1000000;
  7 const int INF=2*0x7ffffff;
  8 inline char nc()
  9 {
 10     static char buf[MAXN],*p1=buf,*p2=buf;
 11     return p1==p2&&(p2=(p1=buf)+fread(buf,1,MAXN,stdin))?EOF:*p1++;
 12 }
 13 inline int read()
 14 {
 15     char c=nc();int x=0,f=1;
 16     while(c<'0'||c>'9'){if(c=='-')f=-1;c=nc();}
 17     while(c>='0'&&c<='9'){x=x*10+c-'0',c=nc();}
 18     return x*f;
 19 }
 20 int PetNum;
 21 #define root tree[0].ch[1]
 22 struct node
 23 {
 24     int v,fa,ch[2],rec;
 25 }tree[MAXN];
 26 
 27 int tot,point;
 28 bool ident(int x)
 29 {
 30     return tree[tree[x].fa].ch[0]==x?0:1;
 31 }
 32 void connect(int x,int fa,int how)
 33 {
 34     tree[x].fa=fa;
 35     tree[fa].ch[how]=x;
 36 }
 37 void rotate(int x)
 38 {
 39     int Y=tree[x].fa;
 40     int R=tree[Y].fa;
 41     int Yson=ident(x);
 42     int Rson=ident(Y);
 43     int B=tree[x].ch[Yson^1];
 44     connect(B,Y,Yson);
 45     connect(Y,x,Yson^1);
 46     connect(x,R,Rson);
 47 }
 48 void splay(int x,int to)
 49 {
 50     to=tree[to].fa;
 51     while(tree[x].fa!=to)
 52     {
 53         if(tree[tree[x].fa].fa==to) rotate(x);
 54         else if(ident(x)==ident(tree[x].fa)) rotate(tree[x].fa),rotate(x);
 55         else rotate(x),rotate(x);
 56     }
 57 }
 58 void newpoint(int x,int fa)
 59 {
 60     tree[++tot].v=x;
 61     tree[tot].fa=fa;
 62     tree[tot].rec=1;
 63 }
 64 void insert(int x)
 65 {
 66     point++;
 67     if(tot==0){newpoint(x,0);root=tot;return ;}
 68     int now=root;
 69     while(1)
 70     {
 71         if(tree[now].v==x)
 72         {
 73             tree[now].rec++;
 74             splay(now,root);
 75             return ;
 76         }
 77         int nxt=x<tree[now].v?0:1;
 78         if(!tree[now].ch[nxt])
 79         {
 80             newpoint(x,now);
 81             tree[now].ch[nxt]=tot;
 82             splay(tot,root);
 83             return ;
 84         }
 85         now=tree[now].ch[nxt];
 86     }
 87 }
 88 int lower(int x)
 89 {
 90     int ans=-INF;
 91     int now=root;
 92     while(now)
 93     {
 94         if(tree[now].v<=x)   ans=max(ans,tree[now].v);
 95         int nxt=x<tree[now].v?0:1;
 96         if(tree[now].ch[nxt]==0)    return ans;
 97         now=tree[now].ch[nxt];
 98     }
 99     return ans;
100 }
101 int upper(int x)
102 {
103     int ans=INF;
104     int now=root;
105     while(now)
106     {
107         if(tree[now].v>=x)   ans=min(ans,tree[now].v);
108         int nxt=x<tree[now].v?0:1;
109         if(tree[now].ch[nxt]==0)    return ans;
110         now=tree[now].ch[nxt];
111     }
112 }
113 int main()
114 {
115     #ifdef WIN32
116     freopen("a.in","r",stdin);
117     #else
118     #endif
119     int n=read(),ans=read();
120     n=n-1;
121     insert(1<<30);
122     insert(-1<<30);
123     insert(ans);
124     while(n--)
125     {
126         int p=read();
127         int pre=lower(p);
128         int lat=upper(p);
129         ans+=min(abs(pre-p),abs(lat-p));
130         insert(p);
131     }
132     printf("%d",ans);
133 }

 


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

-Advertisement-
Play Games
更多相關文章
  • 題目如下: 這題我剛開始被示例給迷惑了,是將key和value分開輸入的,類似於cin>>key>>value,這裡應該是要講每行字元串連接成一個新的字元串,然後遍歷整個字元串,遇到:表示key錄入完畢,遇到,和},要先判斷,的情況,確定,前面沒有},這是才表示value錄入完畢。再就是首碼的問題, ...
  • 1.請求異常處理 請求異常類型: 請求超時處理(timeout): 實現代碼: import requestsfrom requests import exceptions #引入exceptions A:請求超時 def timeout_request(): try: response = req ...
  • hasattr(x, y) getattr(x, y) setattr(x, y , v) delattr(x, y)四種反射方法,就是把字元串反射為記憶體地址。 ...
  • 搭建環境 1、win10_X64,其他Win版本也可以。 2、PyCharm版本:Professional-2016.2.3。 搭建準備 1、到PyCharm官網下載PyCharm安裝包。 2、選擇Windows系統的專業版下載。 安裝軟體 1、雙擊安裝包進行安裝。 2、自定義軟體安裝路徑(建議路徑 ...
  • 正所謂怕什麼來什麼,這是知名的“墨菲定律”。Java基礎涵蓋各個方面,敢說Java基礎扎實的人不是剛畢業的學生,就是工作N年的程式員。工作N年的程式員甚至也不敢人人都說Java基礎扎實,甚至精通,往往只是“無他唯熟爾”——熟手而已。 IO這塊我確實怕,它不難,只有兩個方面:輸入/輸出。但你說它用得多 ...
  • 作為PyCharm編輯器的起步,我們理所當然的先寫一個Hello word,並運行它。(此文獻給對IDE不熟悉的初學者) 1,新建一個項目 File --> New Project... 2,新建一個文件 右鍵單擊剛建好的helloWord項目,選擇New --> Python File 3,輸入文 ...
  • 相同點: 它們都可以用於指定執行該腳本使用Python解釋器。 不同點: ...
  • 今天在寫代碼的時候遇到一個奇葩的問題,問題描述如下: 代碼中聲明瞭一個list,將list作為參數傳入了function1()中,在function1()中對list進行了del()即刪除了一個元素。 而function2()也把list作為參數傳入使用,在調用完function1()之後再調用fu ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...