【TOJ 5224】排座位(並查集+二維數組)

来源:https://www.cnblogs.com/kannyi/archive/2018/03/28/8666505.html
-Advertisement-
Play Games

描述 佈置宴席最微妙的事情,就是給前來參宴的各位賓客安排座位。無論如何,總不能把兩個死對頭排到同一張宴會桌旁!這個艱巨任務現在就交給你,對任何一對客人,請編寫程式告訴主人他們是否能被安排同席。 佈置宴席最微妙的事情,就是給前來參宴的各位賓客安排座位。無論如何,總不能把兩個死對頭排到同一張宴會桌旁!這 ...


描述

佈置宴席最微妙的事情,就是給前來參宴的各位賓客安排座位。無論如何,總不能把兩個死對頭排到同一張宴會桌旁!這個艱巨任務現在就交給你,對任何一對客人,請編寫程式告訴主人他們是否能被安排同席。

輸入

輸入第一行給出3個正整數:N(N≤100),即前來參宴的賓客總人數,則這些人從1到N編號;M為已知兩兩賓客之間的關係數;K為查詢的條數。隨後M行,每行給出一對賓客之間的關係,格式為:賓客1 賓客2 關係,其中關係為1表示是朋友,-1表示是死對頭。註意兩個人不可能既是朋友又是敵人。最後K行,每行給出一對需要查詢的賓客編號。

這裡假設朋友的朋友也是朋友。但敵人的敵人並不一定就是朋友,朋友的敵人也不一定是敵人。只有單純直接的敵對關係才是絕對不能同席的。

輸出

對每個查詢輸出一行結果:如果兩位賓客之間是朋友,且沒有敵對關係,則輸出No problem;如果他們之間並不是朋友,但也不敵對,則輸出OK;如果他們之間有敵對,然而也有共同的朋友,則輸出OK but...;如果他們之間只有敵對關係,則輸出No way。

樣例輸入

7 8 4
5 6 1
2 7 -1
1 3 1
3 4 1
6 7 -1
1 2 1
1 4 1
2 3 -1
3 4
5 7
2 3
7 2

樣例輸出

No problem
OK
OK but...
No way

題解

二維數組判斷敵對關係,並查集建立朋友關係。

#include<iostream>
#include<algorithm>
using namespace std;
int p[105],g[101][101];
int find(int r)
{
    if(p[r]!=r)
    p[r]=find(p[r]);
    return p[r];
}
int join(int x,int y)
{
    int fx=find(x),fy=find(y);
    if(fx!=fy)
        p[fx]=fy; 
} 
int init()
{
    for(int i=1;i<=100;i++)
    p[i]=i;
}
int main()
{
    init();
    int n,m,k,i,a,b,c;
    cin>>n>>m>>k;
    for(i=1;i<=m;i++)
    {
        scanf("%d%d%d",&a,&b,&c);
        if(c==-1)
            g[a][b]=g[b][a]=1; 
        if(c==1)
            join(a,b);
    }
    for(i=1;i<=k;i++)
    {
        scanf("%d%d",&a,&b);
        if(find(a)==find(b)&&g[a][b]==0)
            cout<<"No problem"<<endl;
        else if(find(a)!=find(b)&&g[a][b]==0)
            cout<<"OK"<<endl;
        else if(find(a)==find(b)&&g[a][b]==1)
            cout<<"OK but..."<<endl;
        else if(find(a)!=find(b)&&g[a][b]==1)
            cout<<"No way"<<endl;
    }
    return 0;
}

 


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

-Advertisement-
Play Games
更多相關文章
  • 首先,我先表述一下我的需求: 我記筆記比較亂,但我比較容易"半途而廢".文件夾很多,但大都只有一兩個文件.... 所以我需要一種方式,能在不逐個打開文件夾的前提下,"看到每個文件的名字和位置" 最後發現,我需要的應該是目錄樹.....不過我不需要製表符,要統統使用tab 那就擼起袖子開乾 第一部分, ...
  • 下載目錄:https://studygolang.com/dl32位選 go1.10.linux-386.tar.gz64位選 go1.10.linux-amd64.tar.gz uname -a查看本機位數,註意查看本機系統位數i386對應的是32位系統、而i686是i386的一個子集,x86_6 ...
  • 官方使用示例: 當update_or_create的查詢結果大於1個時,那麼就會報錯MultipleObjectsReturned的錯。 糾正方式就是儘可能的縮小查詢範圍,實在無法確認,那就老老實實的使用先判斷是否存在再進行更新。 關鍵報錯信息: MultipleObjectsReturned: g ...
  • 一、Python簡介 Python是著名的“龜叔”Guido van Rossum在1989年聖誕節期間,為了打發無聊的聖誕節而編寫的一個編程語言。Python為我們提供了非常完善的基礎代碼庫,覆蓋了網路、文件、GUI、資料庫、文本等大量內容,被形象地稱作“內置電池(batteries includ ...
  • 時間限制1000ms 記憶體限制65536K 在右側我們給出了一個已經基本完成的程式,讀入了一個字元串,調用了一個叫str_len的函數來計算這個字元串的長度,並輸出。 聰明的你應該已經發現了,這個叫str_len的函數並沒有完成,在不修改函數原型的情況下,請完成str_len函數,實現我們上述的功能 ...
  • 每次閱讀7個章節,因為原先有一些8086彙編的基礎,所以看起來也很快,主要是實驗驗證剛開始比較陌生,有點費時間 1.因為處理器架構的相容,所以對於寄存器和記憶體處理支持多種長度的操作: a.記憶體處理需要額外的彙編標識表明操作長度(PTR-pointer): BYTE PTR 8bit WORD PTR ...
  • 學習目的: MongoDB的安裝 正式步驟 (VMWare 虛擬機上無法安裝這個MongoDB的自啟動服務,如果你能辦到,請多賜教) Step1:MongoDB的簡介 MongoDB是一個基於分散式文件存儲的資料庫。由C++語言編寫。旨在為WEB應用提供可擴展的高性能數據存儲解決方案。 mongoD ...
  • 這學期還是下定決心打算考研了,現在已經定好學校和專業。因為是跨考,所以打算早點開始專業課。我考的那個學校電腦技術專業需要考《數據結構》、《操作系統》、《電腦網路》。個人認為,數據結構和操作系統是很基礎的東西,如果學好了對於學其他東西都會有很大幫助,所以我打算從數據結構開始。因為C語言剛開始一直是 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...