UOJ#386. 【UNR #3】鴿子固定器(鏈表)

来源:https://www.cnblogs.com/zwfymqz/archive/2018/09/11/9630391.html
-Advertisement-
Play Games

題意 題目鏈接 為了固定S**p*鴿鴿,whx和zzt來到鴿具商店選購鴿子固定器。 鴿具商店有 nn 個不同大小的固定器,現在可以選擇至多 mm 個來固定S**p*鴿鴿。每個固定器有大小 sisi 和牢固程度 vivi。 如果他們選購的固定器大小不一或是不牢固,固定S**p*鴿鴿的時候肯定會很頭疼, ...


題意

題目鏈接

為了固定S**p*鴿鴿,whx和zzt來到鴿具商店選購鴿子固定器。

鴿具商店有 nn 個不同大小的固定器,現在可以選擇至多 mm 個來固定S**p*鴿鴿。每個固定器有大小 sisi 和牢固程度 vivi。

如果他們選購的固定器大小不一或是不牢固,固定S**p*鴿鴿的時候肯定會很頭疼,所以定義選擇的物品總牢固程度和的 dvdv 次方減大小極差的 dsds 次方為這個方案的價值,求不同選購方案中,價值的最大值。

Sol

非常好的一道猜結論

如果我們按$s$排序後,我們就可以枚舉$max  \ s_i$和$min \ s_i$

考慮到$M$很小,對於長度$\leqslant M$的部分直接暴力枚舉

那長度$ > M$的呢?很顯然,我們需要暴力裡面$v$值較大的點

因此我們用一個鏈表維護處所有的數,然後從小到大枚舉$v$值,同時枚舉一下能覆蓋到它的區間來更新答案

#include<cstdio>
#include<algorithm>
#include<queue>
#define Pair pair<int, int> 
#define MP(x, y) make_pair(x, y)
#define fi first
#define se second
#define LL long long
 #define int long long  
using namespace std;
const int MAXN = 2 * 1e5 + 10, B = 25000;
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 N, M, ds, dv;
int l[MAXN], r[MAXN];
LL Get(LL x, int opt) {
    if(opt == 1) return x;
    else return x * x;
}
struct Node {
    int s, v;
    bool operator < (const Node &rhs) const {
        return s == rhs.s ? v < rhs.v : s < rhs.s;
    }
}a[MAXN];
main() {
    priority_queue<Pair> q;
    N = read(); M = read(); ds = read(); dv = read();
    for(int i = 1; i <= N; i++) {
        a[i].s = read(), a[i].v = read(); // 澶у皬 / 鐗㈠滻紼嬪害
        
    }
    sort(a + 1, a + N + 1);
    for(int i = 1; i <= N; i++) {
        q.push(MP(-a[i].v, i));
    }
    int ans = 0;
    for(int i = 1; i <= N; i++) {
        int sum = 0;
        for(int j = i; j <= i + M - 1 && j <= N; j++) {
            sum += a[j].v;
            ans = max(ans, Get(sum, dv) - Get(a[j].s - a[i].s, ds));
        }
    }
  // printf("%d\n", ans);
    for(int i = 1; i <= N; i++) r[i] = i + 1, l[i] = i - 1;
    while(!q.empty()) {
     //   printf("%d\n", q.top().fi);
        int pos = q.top().se; q.pop();
        int sum = a[pos].v, x = pos, y = pos;
        for(int j = 1; j < M; j++) {
            if(l[x]) x = l[x], sum += a[x].v;
            else if(r[y] <= N) y = r[y], sum += a[y].v;
        }
        while(x != r[pos] && y <= N) {
            ans = max(ans, Get(sum, dv) - Get(a[y].s - a[x].s, ds));
            sum -= a[x].v;
            x = r[x]; y = r[y];
            sum += a[y].v;
        }
        r[l[pos]] = r[pos];
        l[r[pos]] = l[pos];
    }
    printf("%lld", ans);
    
    return 0;
}
/*
*/

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

-Advertisement-
Play Games
更多相關文章
  • 給你一個字元串,比如‘abc’,請列印出該字元串的所有排列組合: 以‘abc’為例,輸出的結果應該是:'abc', 'acb', 'bac', 'bca', 'cab', 'cba' 請用python代碼編碼實現: ...
  • JSON(JavaScript Object Notation) 是一種輕量級的數據交換格式,它使得人們很容易的進行閱讀和編寫。同時也方便了機器進行解析和生成。JSON在數據交換中起到了一個載體的作用,承載著相互傳遞的數據。JSON適用於進行數據交互的場景,比如網站前臺與後臺之間的數據交互。 jso ...
  • 用來計算連續變數的發生率,說的很抽象,簡單說就是單獨拿出來沒什麼太大用,但並不是說這個沒什麼用,相反這個太重要了,這玩意能讓你看清世界的真相 先看個圖,像這樣的線性就是正太分佈 這是一個標準的正態分佈 正太分佈有4個特點 呈鐘形分佈,是對稱的 分佈的集中趨勢(均值、中位數、眾數)都一樣 中間最高的部 ...
  • 今天學習的內容是:JDBC http://www.cnblogs.com/centor/p/6142775.html 首先我們把這部分內容仔細閱讀然後複製粘貼到下麵 以mysql為例 工具:eclipse MySQL5.6 MySQL連接驅動:mysql-connector-java-5.1.27. ...
  • 給一個鏈表,若其中包含環,請找出該鏈表的環的入口結點,否則,輸出null 1.找鏈表倒數第k個結點,輸入一個鏈表,輸出該鏈表中倒數第k個結點。第一個指針走(k-1)步,到達第k個節點,兩個指針同時往後移動,當第一個結點到達末尾的時候,第二個結點所在位置就是倒數第k個節點了 2.原理有點像上面的,定義... ...
  • 前言 在 "上一篇" 中我們學習了結構型模式的外觀模式和裝飾器模式。本篇則來學習下組合模式和過濾器模式。 組合模式 簡介 組合模式是用於把一組相似的對象當作一個單一的對象。組合模式依據樹形結構來組合對象,用來表示部分以及整體層次。這種類型的設計模式屬於結構型模式,它創建了對象組的樹形結構。 簡單來說 ...
  • 最近由於項目需要,在研究打壓測試工具,以及當測試連接過多後端伺服器配置問題 測試工具選用locust,locust中文意思為蝗蟲,可以想象,locust就像成片的蝗蟲,撲向我們的服務。 它支持分散式的打壓測試,每個實例可自定義執行任務,執行任務可用python腳本實現,具體如何寫python腳本這裡 ...
  • 監聽器的分類 監聽域對象自身創建和銷毀的監聽器: ①ServletContextListener介面 監聽 SercvletContext對象 ②HttpSessionListener介面 監聽 HttpSession對象 ③ServletRequestListener介面 監聽 ServletRe ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...