洛谷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
  • 移動開發(一):使用.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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...