BZOJ4868: [Shoi2017]期末考試

来源:https://www.cnblogs.com/zwfymqz/archive/2018/03/20/8612909.html
-Advertisement-
Play Games

Description 有n位同學,每位同學都參加了全部的m門課程的期末考試,都在焦急的等待成績的公佈。第i位同學希望在第ti天 或之前得知所.有.課程的成績。如果在第ti天,有至少一門課程的成績沒有公佈,他就會等待最後公佈成績的課程 公佈成績,每等待一天就會產生C不愉快度。對於第i門課程,按照原本 ...


Time Limit: 20 Sec  Memory Limit: 512 MB
Submit: 936  Solved: 426
[Submit][Status][Discuss]

Description

有n位同學,每位同學都參加了全部的m門課程的期末考試,都在焦急的等待成績的公佈。第i位同學希望在第ti天 或之前得知所.有.課程的成績。如果在第ti天,有至少一門課程的成績沒有公佈,他就會等待最後公佈成績的課程 公佈成績,每等待一天就會產生C不愉快度。對於第i門課程,按照原本的計劃,會在第bi天公佈成績。有如下兩種 操作可以調整公佈成績的時間:1.將負責課程X的部分老師調整到課程Y,調整之後公佈課程X成績的時間推遲一天 ,公佈課程Y成績的時間提前一天;每次操作產生A不愉快度。2.增加一部分老師負責學科Z,這將導致學科Z的出成 績時間提前一天;每次操作產生B不愉快度。上面兩種操作中的參數X,Y,Z均可任意指定,每種操作均可以執行多次 ,每次執行時都可以重新指定參數。現在希望你通過合理的操作,使得最後總的不愉快度之和最小,輸出最小的不 愉快度之和即可  

Input

第一行三個非負整數A,B,C,描述三種不愉快度,詳見【問題描述】; 第二行兩個正整數n,m(1≤n,m≤105),分別表示學生的數量和課程的數量; 第三行n個正整數ti,表示每個學生希望的公佈成績的時間; 第四行m個正整數bi,表示按照原本的計劃,每門課程公佈成績的時間。 1<=N,M,Ti,Bi<=100000,0<=A,B,C<=100000  

Output

輸出一行一個整數,表示最小的不愉快度之和。  

Sample Input

100 100 2
4 5
5 1 2 3
1 1 2 3 3

Sample Output

6
由於調整操作產生的不愉快度太大,所以在本例中最好的方案是不進行調整; 全部
5 的門課程中,最慢的在第 3 天出成績;
同學 1 希望在第 5 天或之前出成績,所以不會產生不愉快度;
同學 2 希望在第 1 天或之前出成績,產生的不愉快度為 (3 - 1) * 2 = 4;
同學 3 希望在第 2 天或之前出成績,產生的不愉快度為 (3 - 2) * 2 = 2;
同學 4 希望在第 3 天或之前出成績,所以不會產生不愉快度;
不愉快度之和為 4 + 2 = 6 。

HINT

 

 存在幾組數據,使得C = 10 ^ 16

 

Source

黑吉遼滬冀晉六省聯考

 

考場上還是靜不下心來

總感覺這題是個dp

然後直接棄掉了。

其實還是挺簡單的。

我們欽定一個試卷被批完的最晚時間

然後通過二分+首碼和計算出學生的不愉快度

再利用二分+尾碼和計算出讓最後一個被批完的試卷的時間滿足要求的不愉快的

兩者求和取最小值就可以了

 

這道題的關鍵是看出學生不滿意度和試卷被批完的時間之間的單調關係

然後要想到枚舉時間

#include<cstdio>
#include<cmath>
#include<algorithm>
#define int unsigned long long 
using namespace std;
const int MAXN=1e5+10;
const int INF=1e19;
inline int read()
{
    char c=getchar();int x=0,f=1;
    while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}
    while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();}
    return x*f;
}
int A,B,C;
int N,M;
int t[MAXN],b[MAXN];
int sumt[MAXN],sumb[MAXN];//t的首碼與b的尾碼 
int limit,ans=INF;
main()
{
    #ifdef WIN32
    freopen("a.in","r",stdin);
    #endif
    A=read();B=read();C=read();
    N=read();M=read();
    for(int i=1;i<=N;i++) t[i]=read();
    for(int i=1;i<=M;i++) b[i]=read(),limit=max(limit,b[i]);
    sort(t+1,t+N+1);
    sort(b+1,b+M+1);
    for(int i=1;i<=N;i++) sumt[i]=t[i]+sumt[i-1];
    for(int i=M;i>=1;i--) sumb[i]=b[i]+sumb[i+1];
    for(int i=1;i<=limit;i++)
    {
        int l=1,r=N,ans1=0,ans2=0,now=0;
        while(l<=r)
        {
            int mid=l+r>>1;
            if(t[mid]<i) ans1=mid,l=mid+1;
            else r=mid-1;
        }
        l=1,r=M;
        while(l<=r)
        {
            int mid=l+r>>1;
            if(b[mid]>i) 
                ans2=mid,r=mid-1;
            else l=mid+1;
        }
        if(ans1!=0) now+=(ans1*i-sumt[ans1])*C;
        if(ans2!=0) 
        {
            int need=(sumb[ans2]-(M-ans2+1)*i);
            if(A>=B) now+=need*B;
            else
            {
                int have=(ans2-1)*i-(sumb[1]-sumb[ans2]);
                if(have>=need) now+=need*A;
                else now+=have*A+(need-have)*B;
            }
        }
        ans=min(ans,now);
    }
    printf("%lld",ans);
    return 0;
}

 


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

-Advertisement-
Play Games
更多相關文章
  • 軟體質量與測試 第二周作業 WordCount Github地址: https://github.com/Hu-Peking/WordCount PSP2.1: 解題思路: 1、將程式的功能需求分為基礎功能和拓展功能,按先後順序分別實現兩部分的內容; 2、先在IDE中實現對電腦中指定目錄下的文件的讀 ...
  • MySQL事務隔離級別 1. 臟讀: 騙錢的手段, 兩個視窗或線程分別調用資料庫轉賬表,轉賬後未提交,對方查看到賬後,rollback,實際錢沒轉. 演示方法: mysql預設的事務隔離級別為repeatable-read 比Oracle高,因為mysql本身弱 使用select @@tx_isol ...
  • 今天發現一個超級坑的異常, 如上, 問題所在:頁面中的el表達式中拿不到User對象中的'name'值 頁面裡面的${USER.name}改為${USER.username}就解決了 ...
  • 為什麼這樣說呢,我幾個月前就開始學python,但是一直都沒有進步,還就只是會一些其它語言的共性的問題,也就是新學習的約等於0. 後來一直找一些適合自己的教材,通過同學找到了一個學長的教程。 開始了新的python旅程 最近打字有點懶了五筆都有點生疏了 還是看手抄版的筆記吧 給自己學習的動力從新的一 ...
  • 註:這裡只描述使用方法,具體類的概念長篇大論就不要為難我這個懶人了。 總之一句話編程語言只是一個工具,會用就行,好用就行。打破砂鍋問到底,我覺得有必要研究一下C,彙編,電子鏈路等。 ...
  • 一、SpringData入門 在上次學SpringBoot的時候,那時候的教程就已經涉及到了一點SpringData JPA的知識了。當時還是第一次見,覺得也沒什麼大不了,就是封裝了Hibernate的API而已。 然後在慕課網上又看到了SpringData的教程了。於是就進去學習了一番。 教程地址 ...
  • 一、實體基本映射 二、實體表間映射 1、一對一實體映射:人與地址 2、一對多實體映射:員工表與部門表 3、多對多實體映射:老師與學生 ...
  • 1,首字母大寫 2,replace,替換 查幫助 如果是面向過程的函數用法,直接help( 函數名 ),如help( abs ) 用法說明: replace(...) S.replace(old, new[, count]) -> string Return a copy of string S w ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...