P6818 [PA2013]Działka 題解

来源:https://www.cnblogs.com/xztx666/archive/2023/04/29/17363914.html
-Advertisement-
Play Games

P6818 [PA2013]Działka 前言 我太菜了。。。。 對著 jiangly 大佬的題解研究了一下午研究了一下午才搞出來(淚目。 作為一個蒟蒻,我就詳細的講一下我對與本題的理解。 題意 本題的的題意描述的還是比較明瞭。 在二維坐標系中,輸入 $n$ 個點 $m$ 次詢問, 每次詢問,給出 ...


P6818 [PA2013]Działka

前言

我太菜了。。。。

對著 jiangly 大佬的題解研究了一下午研究了一下午才搞出來(淚目。

作為一個蒟蒻,我就詳細的講一下我對與本題的理解。

題意

本題的的題意描述的還是比較明瞭。

在二維坐標系中,輸入 \(n\) 個點 \(m\) 次詢問,

每次詢問,給出一個矩陣,

求出矩陣內極大凸包的面積。

題解

1.如何求面積

二維平面的計算幾何題,較常見的做法就是利用叉積。本題亦如此。

叉積有個優美的性質,我們可以發現對於 \(\vec{a} \times \vec{b}\) 可以在二維平面賦予特殊意義( \(S\) 為三角形面積)。

\(\vec{a} \times \vec{b} = 2S\)

利用這個性質我們就可以求出任意凸包的面積。

舉個例子,\(4\) 個點坐標為 \((1 , 1) (1 , 3) (3 , 3) (3 , 1)\) 在此記為 \(0\) 號點到 \(3\) 號點,\(G\) 記為原點,

那要求出其凸包的面積就可以寫作:

\({ \vec{G0} \times \vec{G3} + \vec{G3} \times \vec{G2} + \vec{G1} \times \vec{G0} + \vec{G1} \times \vec{G0} \over 2}\)

其實就可以理解為綠色的三角形相加。

再容斥一下減去紅色三角(由於叉乘的順尋原因出來的紅色三角形負數)。

剩下的就是索要求的凸包面積。

因為本題 \(n \le 3000\) 我們可以考慮直接 \(O(n ^ 2)\) 預處理出每兩個向量的叉乘(其實不是任意兩個的叉乘,詳見第三部分)。

呢麽下麵的任務就是快速找到凸包外面的點。


2.如何找凸包

如何找凸包呢?有一個十分優雅的方法。可以考慮尋找類似於四分之一扇形的凸包,然後每次旋轉找到 \(4\) 個半圓再求和。假設我們先找右上角的扇形。

對於如下圖形如何優美的找到凸包呢?

我們可以考慮將點以優先 \(x\) 從大到小後 \(y\) 從大到小的順序找(過程可以順便預處理前面提到的任意兩點的距離)。

手模一下發現,我們先會從 \(1\) 號點就可以輕易的找到 \({1 , 3 , 4}\) 的點集。

呢如何記錄高效的記錄答案呢?


3.如何記錄答案

直接枚舉每個問題,顯然會 T 飛。

考慮在記錄兩點間距離的時候直接記錄最外面凸包的距離,例如前面的圖片,在記錄 \(\vec{1} \times \vec{4}\) 的時可以直接記錄為 \(\vec{1} \times \vec{3} + \vec{3} \times \vec{4}\)。樣我們在統計答案的時候實際上只需要記錄只需要記錄他最接近邊界的兩個點就可了。

考慮每一次記錄答考慮使用線段樹加掃描線的思想,如下圖為每個點。

當我們更新完最外面的橙色的點還沒有處理藍色的點的時候,考慮有哪些區間里的提問是可以被更新的。

黃色的區間是可以被更新的,利用掃描線的思想做到 \(O(m \log m)\) 維護每個圖形的邊界。


\(\bullet\) 加強版

模擬賽出了這道題的加強版,若坐標的範圍改成 \(-10^7 \le x ,y \le 10^7\)

兩個辦法,一是使用效率更高的 zkw 線段樹,二是數據離散化。

當然本題用普通線段樹就可以切了。

Code

代碼跟 jiangly 大佬的沒有本質區別,就不粘了(doge去翻上一篇題解吧。


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

-Advertisement-
Play Games
更多相關文章
  • ==資料庫==1、創建資料庫create database [IF NOT EXISTS] 資料庫名; 2、刪除資料庫drop database [IF EXISTS] 資料庫名; 3、切換資料庫select database(); 4、查詢資料庫show databases; —————————— ...
  • 1、四層結構 viewer --> datasources(DataSourceCollection類型) --> datasource --> entities(EntityCollection類型) --> entity 需要學習的方向是:只需要註意每個層與層之間的關係和entity實例如何創建 ...
  • 簡介 模板方法模式(Template Method Pattern)也叫模板模式,是一種行為型模式。它定義了一個抽象公開類,包含基本的演算法骨架,而將一些步驟延遲到子類中,模板方法使得子類可以不改變演算法的結構,只是重定義該演算法的某些特定步驟。不同的子類以不同的方式實現這些抽象方法,從而對剩餘的邏輯有不 ...
  • 轉載請註明 來源:http://www.eword.name/ Author:eword Email:[email protected] 安裝Python 一、查詢是否安裝了Python及安裝路徑 #查看當前Python版本 python --version Python 2.7.16 #查看當前所有 ...
  • B/S結構系統的會話機制(session) 每博一文案 你跑得快,22歲有個家,身邊全是贊嘆,你跑得慢,30歲還在路上追求夢想。有的人為了車,房拼了一輩子, 有的人買輛摩托車走遍了大好江山。你想成為怎樣的人,過怎樣的生活,只要你不後悔就行。 並不是所有人都能在早上七點鐘起床的,也別拿一碗飯來衡量一個 ...
  • 本文首發於公眾號:Hunter後端 原文鏈接:Django筆記三十三之緩存操作 這一節介紹一下如何在 Django 中使用 redis 做緩存操作。 在 Django 中可以有很多種方式做緩存,比如資料庫,比如伺服器文件,或者記憶體,這裡介紹用的比較多的使用 redis 作為緩存。 這篇筆記主要內容如 ...
  • 大部分程式員走入編程世界第一個學習的語言就是C語言。 作為一門古老的編程語言,c語言擁有48年的發展歷程。 為什麼要學習 C語言? C語言是學習電腦程式設計語言的入門語言。最全面的編程面試網站 C語言是一門偏底層的語言,學好它,可以讓你更好的瞭解電腦。 學會了C語言,你就能學習現在任何的高級編程 ...
  • 在前幾篇文章中`LyShark`通過多種方式實現了驅動程式與應用層之間的通信,這其中就包括了通過運用`SystemBuf`緩衝區通信,運用`ReadFile`讀寫通信,運用`PIPE`管道通信,以及運用`ASYNC`反向通信,這些通信方式在應對`一收一發`模式的時候效率極高,但往往我們需要實現一次性... ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...