靈魂寶石 bzoj 2663

来源:http://www.cnblogs.com/lytccc/archive/2016/12/26/6221660.html
-Advertisement-
Play Games

靈魂寶石(1s 128MB)soulgem 【問題描述】 “作為你們本體的靈魂,為了能夠更好的運用魔法,被賦予了既小巧又安全的外形······” 我們知道,魔法少女的生命被存放於一個稱為靈魂寶石(Soul Gem)的裝置內。而有時,當靈魂寶石與軀體的距離較遠時,魔法少女就無法控制自己的軀體了。 在傳 ...


靈魂寶石(1s 128MB)soulgem

【問題描述】 

“作為你們本體的靈魂,為了能夠更好的運用魔法,被賦予了既小巧又安全的外形······” 

我們知道,魔法少女的生命被存放於一個稱為靈魂寶石(Soul Gem)的裝置內。而有時,當靈魂寶石與軀體的距離較遠時,魔法少女就無法控制自己的軀體了。

在傳說中,魔法少女Abel僅通過推理就得到了這個現象的一般法則,被稱為Abel定理:存在宇宙常量R(是一個非負實數,或正無窮),被稱為靈魂寶石常量,量綱

為空間度量(即:長度)。如果某個魔法少女的靈魂寶石與她的軀體的距離嚴格超過R,則她一定無法控制自己的軀體;如果這個距離嚴格小於R,則她一定可以控

制自己的軀體。(這裡的距離指平面的 Euclid距離。) 

註意:該定理不能預言距離剛好為R的情形。可能存在魔法少女A和B,她們離自己的靈魂寶石的距離都恰好為R,但是A可以控制自己的軀體,而B不可以。

現在這個世界上再也沒有魔法少女了,但是我們卻對這個宇宙常量感興趣。我們只能通過之前的世界遺留下來的數據來確定這個常量的範圍了。

每一組數據包含以下信息: 

一共有N個魔法少女及她們的靈魂寶石,分別編號為1-N。

這N個魔法少女所在的位置是(Xi, Yi)。 

這N個靈魂寶石所在的位置是(xi, yi)。 

此時恰好有 K個魔法少女能夠控制自己的軀體。

1.我們認為這個世界是二維的 Euclid 空間。

2.魔法少女與靈魂寶石之間的對應關係是未知的。

3.我們不知道是具體是哪 K個魔法少女能夠控制自己的軀體。

根據以上信息,你需要確定靈魂寶石常量 R可能的最小值 Rmin 和最大值Rmax。

【輸入格式】

第一行包兩個整數:N、K。 
接下來N行,每行包含兩個整數:Xi,Yi,由空格隔開。 
再接下來N行,每行包含兩個整數:xi,yi,由空格隔開。 

【輸出格式】

輸出兩個量:Rmin、Rmax,中間用空格隔開。 
Rmin 一定是一個非負實數,四捨五入到小數點後兩位。 
Rmax 可能是非負實數,或者是正無窮: 
如果是非負實數,四捨五入到小數點後兩位; 
如果是正無窮,輸出“+INF”(不包含引號)。

【輸入樣例】

2 1

1 0

4 0

0 0

4 4

【輸出樣例】

1.00 5.00

【數據範圍】

對於100%的數據: 

1 ≤ N ≤ 50,0 ≤ K ≤ N,-1000 ≤ xi,yi,Xi,Yi ≤ 1000。


 

題解:

主要演算法:二分圖匹配 or 網路流;二分;

題意:對於n個人與n個寶石,每個人需要各自匹配一1顆與其距離小於k的寶石,距離等於k的寶石可以自由選擇是否匹配,求k的最小值與最大值

那麼最小值可以很容易想到二分,連接所有距離小於k的邊,用二分圖匹配檢驗,則為用最大匹配數求最小值

然而最大值並不能直接像最小值一樣求解,因為二分圖求的是最大匹配,這一點模擬樣例就可以得到

於是考慮一點小小的轉化

最大值的檢驗中,我們將距離大於等於k的邊相連

那麼二分圖匹配跑出的結果就是最大不匹配數

總個數減去最大不匹配數即為最小匹配數

只要我們用利用最小匹配數就能最大值

 

  1 #include<algorithm>
  2 #include<iostream>
  3 #include<cstring>
  4 #include<cstdlib>
  5 #include<cstdio>
  6 #include<cmath>
  7 using namespace std;
  8 struct shape
  9 {
 10     double x, y;
 11 };
 12 int n, k;
 13 double l, r;
 14 double ans;
 15 int my[233];
 16 shape a[233];
 17 bool vis[233];
 18 int tot, to[10233], nex[10233], fir[233];
 19 inline double Dis(shape x, shape y)
 20 {
 21     return sqrt((x.x - y.x) * (x.x - y.x) + (x.y - y.y) * (x.y - y.y));
 22 }
 23 inline void Ins(int x, int y)
 24 {
 25     nex[++tot] = fir[x];
 26     fir[x] = tot;
 27     to[tot] = y;
 28 }
 29 bool Find(int u)
 30 {
 31     for(int i = fir[u]; i; i = nex[i])
 32     {
 33         int v = to[i];
 34         if(!vis[v])
 35         {
 36             vis[v] = true; 
 37             if(!my[v] || Find(my[v]))
 38             {
 39                 my[v] = u;
 40                 return true;
 41             }
 42         }
 43     }
 44     return false;
 45 }
 46 inline bool Checkmi(double x)
 47 {
 48     tot = 0;
 49     for(int i = 1; i <= n; ++i) my[i + n] = fir[i] = 0;
 50     for(int i = 1; i <= n; ++i)
 51         for(int j = n + 1; j <= n + n; ++j)
 52             if(Dis(a[i], a[j]) <= x)
 53                 Ins(i, j);
 54     int sum = 0;
 55     for(int i = 1; i <= n; ++i)
 56     {
 57         for(int j = 1; j <= n; ++j)
 58             vis[j + n] = false;
 59         if(Find(i)) ++sum;
 60     }
 61     if(sum < k) return true;
 62     return false;
 63 }
 64 inline bool Checkma(double x)
 65 {
 66     tot = 0;
 67     for(int i = 1; i <= n; ++i) my[i + n] = fir[i] = 0;
 68     for(int i = 1; i <= n; ++i)
 69         for(int j = n + 1; j <= n + n; ++j)
 70             if(Dis(a[i], a[j]) >= x)
 71                 Ins(i, j);
 72     int sum = 0;
 73     for(int i = 1; i <= n; ++i)
 74     {
 75         for(int j = 1; j <= n; ++j)
 76             vis[j + n] = false;
 77         if(Find(i)) ++sum;
 78     }
 79     if(sum < n - k) return false;
 80     return true;
 81 }
 82 int main()
 83 {
 84 //    freopen("soulgem.in", "r", stdin), freopen("soulgem.out", "w", stdout);
 85     scanf("%d%d", &n, &k);
 86     for(int i = 1; i <= n + n; ++i)
 87         scanf("%lf %lf", &a[i].x, &a[i].y);
 88     l = 0, r = 3666;
 89     for(int i = 1; i <= 38; ++i)
 90     {
 91         double mi = (l + r) / 2.0;
 92         if(Checkmi(mi)) l = mi;
 93         else ans = mi, r = mi;
 94     }
 95     printf("%.2lf ", ans);
 96     ans = 3666;
 97     l = 0, r = 3666;
 98     for(int i = 1; i <= 38; ++i)
 99     {
100         double mi = (l + r) / 2.0;
101         if(Checkma(mi)) ans = mi, l = mi;
102         else r = mi;
103     }
104     if(fabs(ans - 3666) <= 0.001) printf("+INF");
105     else printf("%.2lf", ans);
106 }

 


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

-Advertisement-
Play Games
更多相關文章
  • 具體問題是這樣的:我用下麵這段獲取硬碟型信息的代碼做成的exe文件,在機子上測試的時候,出現直接雙擊運行和用管理員身份運行結果不一樣的情況,這個問題該怎麼解決? 得到的結果是這樣的: ...
  • C /.NET 學習之路——從入門到放棄 此系列只包含 C /CLR 學習,不包含應用框架(ASP.NET , WPF , WCF 等)及架構設計學習書籍和資料。 C 入門 1. "《C 本質論》" 2. "《果殼中的C 》" 設計模式 1. "《大話設計模式》" 2. "《Head First 設 ...
  • 什麼是Entity Framework 編寫和管理ADO.NET是一個繁瑣而又無聊的工作。微軟為你的應用提供了一個名為“Entity Framework”的ORM框架來自動化管理你的資料庫。 微軟對Entity Framework給出了以下定義: EF是一個對象關係映射(ORM)框架,它能使開發人員 ...
  • Entity Framework 基礎 本教材將手把手教你使用entity framework,我們將使用entity framework 6.0和visual studio 2012。 以下表格是entity framework的各個重大版本 關於EF版本的更多信息請查看MSDN ...
  • 1. 軟體開發 軟體,即一系列按照特定順序組織的電腦數據和指令的集合。有系統軟體和應用軟體之分。 系統軟體:系統軟體系統軟體是負責管理電腦系統中各種獨立的硬體,使得它們可以協調工作。系統軟體使得電腦使用者和其他軟體將電腦當作一個整體而不需要顧及到底層每個硬體是如何工作的。比如我們講的wind ...
  • 使用java 中的Ftpclient 完成一個圖片上傳的服務,並且使用Nginx 作為代理伺服器進行圖片展示 ...
  • (1)在瀏覽器輸入地址,瀏覽器先去查找hosts文件,將主機名翻譯為ip地址,如果找不到就再去查詢dns伺服器將主機名翻譯成ip地址。 (2)瀏覽器根據ip地址和埠號訪問伺服器,組織http請求信息發送給伺服器。 (3)伺服器收到請求後首先根據Host請求頭判斷當前訪問的是哪台虛擬主機。 (4)服 ...
  • org.apache.commons.pool2.ObjectPool提供了對象池,開發的小伙伴們可以直接使用來構建一個對象池 使用該對象池具有兩個簡單的步驟: 1、創建對象工廠,org.apache.commons.pool2.BasePooledObjectFactory已經對工廠有抽象實現,所 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...