BZOJ4868 Shoi2017期末考試(三分+貪心)

  容易想到枚舉最晚發布成績的課哪天發布,這樣與ti和C有關的貢獻固定。每門課要么貢獻一些調節次數,要么需要一些調節次數,剩下的算貢獻也非常顯然。這樣就能做到平方級別了。

  然后大膽猜想這是一個凸函數三分就能A掉了。具體的,延遲最晚時間一方面會增加學生的不愉快度,這顯然是時間越晚不愉快度增加量越大的,導數單增;另一方面使需要的調節次數減少,這個變化量顯然越來越小,也即老師的不愉快度減少量越來越小,同樣導數單增。所以兩個函數的和也是導數單增的,即是一個凸函數。

  注意存在C=1016,稍微特判一下。

#include<iostream> 
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
#define N 100010
#define inf 2000000000000000000ll
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{int x=0,f=1;char c=getchar();while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();return x*f;
}
int A,B,n,m,a[N],b[N];
ll C,ans=inf;
ll calc(int k)
{ll s=0;for (int i=1;i<=n;i++)if (k>a[i]) if (C==10000000000000000ll) return inf+k;else s+=(k-a[i])*C;ll cnt1=0,cnt2=0;for (int i=1;i<=m;i++)if (b[i]<k) cnt1+=k-b[i];else cnt2+=b[i]-k;if (B<A) s+=1ll*B*cnt2;else if (cnt1>=cnt2) s+=1ll*A*cnt2;else s+=1ll*A*cnt1+1ll*B*(cnt2-cnt1);return s;
}
int main()
{
#ifndef ONLINE_JUDGEfreopen("bzoj4868.in","r",stdin);freopen("bzoj4868.out","w",stdout);const char LL[]="%I64d\n";
#elseconst char LL[]="%lld\n";
#endifcin>>A>>B>>C;n=read(),m=read();int l=1,r=0;for (int i=1;i<=n;i++) a[i]=read();for (int i=1;i<=m;i++) r=max(r,b[i]=read());while (l+3<r){int mid1=l+r>>1,mid2=mid1+1;if (calc(mid1)<calc(mid2)) r=mid2;else l=mid1;}for (int i=l;i<=r;i++) ans=min(ans,calc(i));cout<<ans;return 0;
}

?

轉載于:https://www.cnblogs.com/Gloid/p/10015878.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/387903.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/387903.shtml
英文地址,請注明出處:http://en.pswp.cn/news/387903.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SQL的執行計劃

SQL的執行計劃實際代表了目標SQL在Oracle數據庫內部的具體執行步驟&#xff0c;作為調優&#xff0c;只有知道了優化器選擇的執行計劃是否為當前情形下最優的執行計劃&#xff0c;才能夠知道下一步往什么方向。 執行計劃的定義&#xff1a;執行目標SQL的所有步驟的組合。 我們首…

問卷 假設檢驗 t檢驗_真實問題的假設檢驗

問卷 假設檢驗 t檢驗A statistical Hypothesis is a belief made about a population parameter. This belief may or might not be right. In other words, hypothesis testing is a proper technique utilized by scientist to support or reject statistical hypotheses. Th…

webpack打包ES6降級ES5

Babel是一個廣泛使用的轉碼器&#xff0c;babel可以將ES6代碼完美地轉換為ES5代碼&#xff0c;所以我們不用等到瀏覽器的支持就可以在項目中使用ES6的特性。 安裝babel實現ES6到ES5 npm install -D babel-core babel-preset-es2015 復制代碼安裝babel-loader npm install -D ba…

[轉帖]USB-C和Thunderbolt 3連接線你搞懂了嗎?---沒搞明白.

USB-C和Thunderbolt 3連接線你搞懂了嗎&#xff1f; 2018年11月25日 07:30 6318 次閱讀 稿源&#xff1a;威鋒網 3 條評論按照計算行業的風潮&#xff0c;USB Type-C 將會是下一代主流的接口。不過&#xff0c;在過去兩年時間里&#xff0c;關于 USB-C、Thunderbolt 3、USB 3.1…

sqldeveloper的查看執行計劃快捷鍵F10

簡介&#xff1a;本文全面詳細介紹oracle執行計劃的相關的概念&#xff0c;訪問數據的存取方法&#xff0c;表之間的連接等內容。并有總結和概述&#xff0c;便于理解與記憶!目錄---一&#xff0e;相關的概念Rowid的概念Recursive Sql概念Predicate(謂詞)DRiving Table(驅動表)…

大數據技術 學習之旅_為什么聚焦是您數據科學之旅的關鍵

大數據技術 學習之旅David Robinson, a data scientist, has said the following quotes:數據科學家David Robinson曾說過以下話&#xff1a; “When you’ve written the same code 3 times, write a function.”“當您編寫了3次相同的代碼時&#xff0c;請編寫一個函數。” …

SQL 語句

去重字段里的值 SELECT DISTINCT cat_id,goods_sn,repay FROM ecs_goods where cat_id ! 20014 刪除除去 去重字段 DELETE FROM ecs_goods where goods_id NOT IN ( select bid from (select min(goods_id) as bid from ecs_goods group by cat_id,goods_sn,repay) as b );轉…

無監督學習 k-means_無監督學習-第4部分

無監督學習 k-means有關深層學習的FAU講義 (FAU LECTURE NOTES ON DEEP LEARNING) These are the lecture notes for FAU’s YouTube Lecture “Deep Learning”. This is a full transcript of the lecture video & matching slides. We hope, you enjoy this as much as …

vCenter 升級錯誤 VCSServiceManager 1603

近日&#xff0c;看到了VMware發布的vCenter 6.7 Update 1b的更新消息。其中有一條比較震撼。有誤刪所有VM的概率&#xff0c;這種BUG誰也承受不起。Removing a virtual machine folder from the inventory by using the vSphere Client might delete all virtual machinesIn t…

day28 socketserver

1. socketserver 多線程用的 例 import socket import timeclientsocket.socket() client.connect(("127.0.0.1",9000))while 1:cmdinput("請輸入指令")client.send(cmd.encode("utf-8"))from_server_msgclient.recv(1024).decode("utf…

車牌識別思路

本文源自我之前花了2天時間做的一個簡單的車牌識別系統。那個項目&#xff0c;時間太緊&#xff0c;樣本也有限&#xff0c;達不到對方要求的95%識別率&#xff08;主要對于車牌來說&#xff0c;D,0&#xff0c;O&#xff0c;I&#xff0c;1等等太相似了。然后&#xff0c;漢字…

深度學習算法原理_用于對象檢測的深度學習算法的基本原理

深度學習算法原理You just got a new drone and you want it to be super smart! Maybe it should detect whether workers are properly wearing their helmets or how big the cracks on a factory rooftop are.您剛剛擁有一架新無人機&#xff0c;并希望它變得超級聰明&…

【python】numpy庫linspace相同間隔采樣 詳解

linspace可以用來實現相同間隔的采樣&#xff1b; numpy.linspace(start,stop,num50,endpointTrue,retstepFalse, dtypeNone) 返回num均勻分布的樣本&#xff0c;在[start, stop]。 Parameters(參數): start : scalar(標量) The starting value of the sequence(序列的起始點)…

Spring整合JMS——基于ActiveMQ實現(一)

Spring整合JMS——基于ActiveMQ實現&#xff08;一&#xff09; 1.1 JMS簡介 JMS的全稱是Java Message Service&#xff0c;即Java消息服務。它主要用于在生產者和消費者之間進行消息傳遞&#xff0c;生產者負責產生消息&#xff0c;而消費者負責接收消息。把它應用到實際的…

軟件本地化 pdf_軟件本地化與標準翻譯

軟件本地化 pdfSoftware has become such an essential part of our world that it’s impossible to imagine a life without it. There’s hardly a service or product around us that wasn’t created with software or that runs on software.軟件已成為我們世界的重要組成…

CentOS7+CDH5.14.0安裝全流程記錄,圖文詳解全程實測-8CDH5安裝和集群配置

Cloudera Manager Server和Agent都啟動以后&#xff0c;就可以進行CDH5的安裝配置了。 準備文件 從 http://archive.cloudera.com/cdh5/parcels/中下載CDH5.14.0的相關文件 把CDH5需要的安裝文件放到主節點上&#xff0c;新建目錄為/opt/cloudera/parcel-repo把我們之前下載的…

node.js安裝部署測試

&#xff08;一&#xff09;安裝配置&#xff1a; 1&#xff1a;從nodejs.org下載需要的版本 2&#xff1a;直接安裝&#xff0c;默認設置 &#xff0c;默認安裝在c:\program files\nodejs下。 3&#xff1a;更改npm安裝模塊的默認目錄 &#xff08;默認目錄在安裝目錄下的node…

數據庫不停機導數據方案_如何計算數據停機成本

數據庫不停機導數據方案In addition to wasted time and sleepless nights, data quality issues lead to compliance risks, lost revenue to the tune of several million dollars per year, and erosion of trust — but what does bad data really cost your company? I’…

luogu4159 迷路 (矩陣加速)

考慮如果只有距離為1的邊&#xff0c;那我用在時間i到達某個點的狀態數矩陣 乘上轉移矩陣&#xff08;就是邊的鄰接矩陣&#xff09;&#xff0c;就能得到i1時間的 然后又考慮到邊權只有1~9&#xff0c;那可以把邊拆成只有距離為1的 具體做法是一個點拆成9個然后串聯 1 #includ…

社群系統ThinkSNS+ V2.2-V2.3升級教程

WARNING本升級指南僅適用于 2.2 版本升級至 2.3 版本&#xff0c;如果你并非 2.2 版本&#xff0c;請查看其他升級指南&#xff0c;Plus 程序不允許跨版本升級&#xff01;#更新代碼預計耗時&#xff1a; 2 小時這是你自我操作的步驟&#xff0c;確認將你的 2.2 版本代碼升級到…