街區最短路徑問題

来源:http://www.cnblogs.com/wswang/archive/2016/01/12/5123537.html
-Advertisement-
Play Games

題目來源自http://acm.nyist.net/JudgeOnline/problem.php?pid=7描述一個街區有很多住戶,街區的街道只能為東西、南北兩種方向。住戶只可以沿著街道行走。各個街道之間的間隔相等。用(x,y)來表示住戶坐在的街區。例如(4,20),表示用戶在東西方向第4個街道,...


題目來源自http://acm.nyist.net/JudgeOnline/problem.php?pid=7

 

描述一個街區有很多住戶,街區的街道只能為東西、南北兩種方向。

住戶只可以沿著街道行走。

各個街道之間的間隔相等。

用(x,y)來表示住戶坐在的街區。

例如(4,20),表示用戶在東西方向第4個街道,南北方向第20個街道。

現在要建一個郵局,使得各個住戶到郵局的距離之和最少。

求現在這個郵局應該建在那個地方使得所有住戶距離之和最小;

 
輸入
第一行一個整數n<20,表示有n組測試數據,下麵是n組數據;
每組第一行一個整數m<20,表示本組有m個住戶,下麵的m行每行有兩個整數0<x,y<100,表示某個用戶所在街區的坐標。
m行後是新一組的數據;
輸出
每組數據輸出到郵局最小的距離和,回車結束;
樣例輸入
2
3
1 1
2 1
1 2
5
2 9 
5 20
11 9
1 1
1 20
樣例輸出
2
44


最短路徑肯定是在這幾個點所圍成的圈內的,這樣直接遍歷求和,然後取最小值就好了,代碼如下
  1 #include"header_file.h"
  2 using namespace std;
  3 
  4 int get_max(vector<int> v)
  5 {
  6     int max;
  7     max=v[0];
  8     for(int i=0;i<v.size();i++)
  9     {
 10         if(max<v[i])
 11         {
 12             max=v[i];
 13         }
 14     }
 15     return max;
 16 }
 17 
 18 int get_min(vector<int> v)
 19 {
 20     int min;
 21     min=v[0];
 22     for(int i=0;i<v.size();i++)
 23     {
 24         if(min>v[i])
 25         {
 26             min=v[i];
 27         }
 28     }
 29     return min;
 30 }
 31 
 32 int get_sum(vector<int> vx,vector<int> vy,int x,int y)
 33 {
 34     int sum=0;
 35     for(int i=0;i<vx.size();i++)
 36     {
 37         if((x-vx[i])>=0)
 38         {
 39             sum=sum+x-vx[i];
 40         }
 41         else
 42         {
 43             sum=sum+vx[i]-x;
 44         }
 45     }
 46     for(int i=0;i<vy.size();i++)
 47     {
 48         if((y-vy[i])>=0)
 49         {
 50             sum=sum+y-vy[i];
 51         }
 52         else
 53         {
 54             sum=sum+vy[i]-y;
 55         }
 56     }
 57     return sum;
 58 }
 59 
 60 int get_short_path(vector<int> vx,vector<int> vy,int m)
 61 {
 62     int vx_max,vx_min;
 63     int vy_max,vy_min;
 64     vx_max=get_max(vx);
 65     vx_min=get_min(vx);
 66     vy_max=get_max(vy);
 67     vy_min=get_min(vy);
 68     
 69     vector<int> v;
 70     for(int i=vx_min;i<=vx_max;i++)
 71     {
 72         for(int j=vy_min;j<=vy_max;j++)
 73         {
 74             int sum;
 75             sum=get_sum(vx,vy,i,j);
 76             v.push_back(sum);
 77         }
 78     }
 79     
 80     return get_min(v);
 81 }
 82 
 83 int main(void)
 84 {
 85     int m;
 86     cout<<"input m:";
 87     cin>>m;
 88     
 89     vector<int> vx,vy;
 90     
 91     for(int i=0;i<m;i++)
 92     {
 93         int x,y;
 94         cin>>x>>y;
 95         vx.push_back(x);
 96         vy.push_back(y);
 97     }
 98     
 99     cout<<get_short_path(vx,vy,m);
100 }

 




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

-Advertisement-
Play Games
更多相關文章
  • 這段時間一直比較忙,一忙起來真感覺自己就只是一臺掙錢的機器了(說的好像能掙到多少錢似的,呵呵);這會兒難得有點兒空閑時間,想把前段時間開發微信公眾號支付遇到問題及解決方法跟大家分享下,這些“暗坑”能不掉就不掉吧,要不然關鍵時刻出問題,真是讓人急的焦頭爛額。 雙12客戶的商城活動正在蓄勢進行...
  • 我們有時候在工作流開發中可能會遇到這樣的需求,就是已經審批結束的流程,可能我們還是仍然需要修改業務表的結果,而且我們需要一個時間期限,比如:在5天內可以進行修改,這個時候我們就需要得到我們最後一步審批的時間,我們可以通過下麵這個sql查詢到該時間SELECT MAX(COMM.TIME_) FRO....
  • Python3中int、float、str、list、dict、tuple類的內建方法
  • 本小節我們來做一個好玩的事情,就是計數器,還記得在做LED自加實驗時我們就曾經提到過關於計數器的相關議題,那麼這節我們就來討論討論。 探討一下如下的問題:請用verilog記八個數的寫法,分析這個可以更好的理解觸發器的工作原理。1. reg [3:0]cnt; always@(pose...
  • Sub Macro2()'' Macro2 Macro'' Keyboard Shortcut: Ctrl+d' ActiveCell.Select ActiveSheet.Paste Selection.ShapeRange.ScaleHeight 0.6, msoFalse, msoScaleF...
  • 理解什麼是繼承首先我們知道,面對對象有三大特征:封裝:解決了數據的安全性問題繼承:解決了代碼的重用問題多態:解決了程式的擴展問題上一篇博客中,我們瞭解了一下封裝,現在我了再來看看什麼是繼承。在現實生活中,我們可以把封裝理解成兒子對父親財產的繼承。而在面向對象程式設計中的繼承,是一個對象從另一個對象獲...
  • 在以前的博客裡面,我們介紹了在java領域中大部分的知識點,從最基礎的java最基本語法到SSH框架。這裡面應該包含了在java領域裡面的大部分內容了吧。但是,那些知識點是讓我們從一個應用的層面上瞭解了java,java程式真正底層的運行機制和一些底層虛擬機的工作我們還不瞭解,雖然這些內容在我們真正...
  • 避免使用終結方法(finalizer)終結方法(finalizer)通常是不可預測的,也是很危險的,一般情況下是不必要的。不要把finalizer當成C++中析構函數的對應物。java中,當對象不可達時(即沒有引用指向這個對象時),會由垃圾回收器來回收與該對象相關聯的記憶體資源;而其他的記憶體資源,則一...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...