結題報告

来源:https://www.cnblogs.com/eason66-blog/archive/2020/01/30/P2698-USACO12MARFlowerPot.html
-Advertisement-
Play Games

題目:點此 思路:{ 先讀入,再排序,然後迴圈{ 兩個單調隊列記端點,來一個數據,先維護,然後一邊彈即將過時的數據,一邊記錄(萬一這次是最優解,下次不是最優解(過時)),如果比最小值小就更新,最後進隊。兩單調隊列同思路。 } 如果最小值沒變就輸出-1,否則輸出最小值。 } 犯的錯誤:{ 1.有很多沒 ...


題目:點此

思路:{

先讀入,再排序,然後迴圈{

兩個單調隊列記端點,來一個數據,先維護,然後一邊彈即將過時的數據,一邊記錄(萬一這次是最優解,下次不是最優解(過時)),如果比最小值小就更新,最後進隊。兩單調隊列同思路。

}

如果最小值沒變就輸出-1,否則輸出最小值。

}

犯的錯誤:{

1.有很多沒用的代碼。

2.記左端點和記右端點的許多判斷條件是不一樣的,我寫成一樣的了。

3.沒有將不是最優解的數據彈出。

4.不能將判斷數據是不是可行的If放在彈過時數據的while里。

5.應該一邊彈一邊更新最小值,而不是只記錄。

6.不要的代碼沒刪乾凈。

7.複製代碼時沒把要修改的地方改完。

8.想太多。

}

收穫:{

1.把沒用的代碼去掉。

2.不要想當然。

3.要考慮周全。

4.不要的代碼要刪乾凈。

5.不要偷懶。

6.不要想太多。

}

代碼:

 1 #include <iostream>
 2 #include <algorithm>
 3 #include <deque>
 4 #include <cmath>
 5 #include <cstdio>
 6 using namespace std;
 7 struct drop{
 8     int x,y;
 9 }a[100000];
10 bool cmp(drop c,drop d){
11     return c.x<d.x;
12 }
13 deque <int> maxz,minz;
14 int main(){
15     int wl,ans=2147483645;
16     int n,d;
17     cin >> n >> d;
18     for(int i=0;i<n;i++){
19         scanf("%d %d",&a[i].x,&a[i].y);
20     }
21     sort(a,a+n,cmp);
22     int npos=ans;
23     wl=npos+1;
24     for(int i=0;i<n;i++){
25         int old;
26         while(!maxz.empty()&&a[maxz.back()].y<a[i].y){
27             maxz.pop_back();
28         }
29         while(!maxz.empty()&&a[maxz.front()].y-a[i].y>=d){
30             old=maxz.front();
31             maxz.pop_front();
32             wl=a[i].x-a[old].x;
33             if(ans>wl){
34                 ans=wl;
35             }
36         }
37         maxz.push_back(i);
38         while(!minz.empty()&&a[minz.back()].y>a[i].y){
39             minz.pop_back();
40         }
41         old=minz.front();
42         while(!minz.empty()&&a[i].y-a[minz.front()].y>=d){
43             old=minz.front();
44             minz.pop_front();
45             wl=a[i].x-a[old].x;
46             if(ans>wl){
47                 ans=wl;
48             }
49         }
50         minz.push_back(i);
51     }
52     if(ans==npos){
53         cout << -1;
54         return 0;
55     }
56     cout << ans;
57     return 0;
58 }

評測


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

-Advertisement-
Play Games
更多相關文章
  • 本篇主要詳細講解Python中常用的列表、字典、元組相關的操作 一、列表 列表是我們最以後最常用的數據類型之一,通過列表可以對數據實現最方便的存儲、修改等操作 通過下標獲取元素 #先定義一個列表 letters = ['a', 'b', 'c', 'd', 'e'] letters[1] #輸出:b ...
  • 1.下載和安裝eclipse 下載地址:http://www.eclipse.org/downloads/eclipse-packages/ 出現圖1-25所示下載界面。選擇Eclipse IDE for Java Developers,根據自己安裝的JDK, 決定是下載32位還是64位。下載完成後 ...
  • 用 C++ 封裝的普通的二叉樹,涉及二叉樹的創建,先序遍歷(遞歸、非遞歸),中序遍歷(遞歸、非遞歸),後序遍歷(遞歸、非遞歸),層序遍歷。 使用 STL std::queue 以及 先序 方法創建二叉樹,使用成員 nullVal 代表空。 先序、中序、後序 三種非遞歸 使用 STL std::sta ...
  • 入門學習時,進行簡單的Java程式編寫,我們可以使用文本編輯器,比如:記事本。但是,記事本功能不夠強大,我們可以考慮使用“更加強大的記事本”,常見的有如下三種軟體: 1.Notepad++ 2.UltraEdit 3.EditPlus 在我們真正學習開發中,包括以後在企業中從事軟體開發時,一般使用集 ...
  • DOS命令已經基本退出普通使用者的歷史舞臺了,但是仍然有必要掌握幾個常用的命令,便於在某些情況下更順暢的操作程式。 1.cd 目錄路徑 進入一個目錄 2.cd .. 進入父目錄 3.dir 查看本目錄下的文件和子目錄列表 4.cls 清楚屏幕命令 5.上下鍵 查找敲過的命令 6.Tab鍵 自動補齊命 ...
  • 1.Java對大小寫敏感,如果出現了大小寫拼寫錯誤,程式無法運行。 2.關鍵字public被稱作訪問修飾符(access modifier),用於控製程序的其它部分對這段代碼的訪問級別。 3.關鍵字class 的意思是類。Java是面向對象的語言,所有代碼必須位於類裡面。 4.一個源文件中至多只能聲 ...
  • ·常見問題-1:提示“javac不是內部或外部命令……” 圖1-22常見錯誤-1 出錯原因:Path變數配置錯誤導致沒有找到javac命令 解決方案:參考1.4.2 <環境變數Path的配置>,細心重新設置Path,配置完成後需要重新輸入cmd打開命令行視窗。 ·常見問題-2:文件夾中可以看到Wel ...
  • ·使用記事本,編寫代碼 【示例1-1】使用記事本開發第一個Java程式 public class Welcome{ public static void main(String[] args){ System.out.println("Hello Java!"); } } 可在d盤下建立文件夾myc ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...