【TOJ 3955】NKU ACM足球賽(加權並查集)

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

描述 NKU ACM最近要舉行足球賽,作為此次賽事的負責人,Lee要對報名人員進行分隊。分隊要遵循如下原則: 一個人不能加入多支隊伍;不認識的人不能分在同一隊;如果a和b認識,b和c認識,那麼認為a和c也認識;每支隊伍上限8人,下限5人;儘量使隊伍滿員。由於參賽人數很多,Lee表示無能為力,所以請你 ...


描述

NKU ACM最近要舉行足球賽,作為此次賽事的負責人,Lee要對報名人員進行分隊。分隊要遵循如下原則:

一個人不能加入多支隊伍;
不認識的人不能分在同一隊;
如果a和b認識,b和c認識,那麼認為a和c也認識;
每支隊伍上限8人,下限5人;
儘量使隊伍滿員。
由於參賽人數很多,Lee表示無能為力,所以請你幫助Lee編程解決比賽有多少隊伍。

輸入

第一行輸入兩個整數,n和m,n(1<=n<=300000)代表報名人數,m(1<=m<=500000)代表關係數。接下來m行每行兩個整數a(1<=a<=n)和b(1<=b<=n)表示a和b認識。

輸出

輸出一行,包含一個整數,表示隊伍數量。

樣例輸入

11 10
1 2
2 3
2 6
3 4
4 5
5 6
7 9
9 11
11 8
8 10

樣例輸出

 2

#include<iostream>
#include<algorithm>
using namespace std;
int p[300005],rank[300005]; 
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;
        rank[fy]+=rank[fx];
        rank[fx]=1;                      //把加過的秩數組變為1
    }
}
int main()  
{  
    int n,m,a,b,s;
    while(cin>>n>>m)
    {
        s=0;
        for(int i=0;i<=300005;i++)
            p[i]=i,rank[i]=1;
        while(m--)
        {
            scanf("%d%d",&a,&b);
            join(a,b);
        }
        for(int i=1;i<=n;i++)
        {
            if(rank[i]>=5)
            {
                if(rank[i]%8>=5)
                    s+=rank[i]/8+1; 
                else 
                    s+=rank[i]/8;
            }
        }
        printf("%d\n",s);
    }
    return 0;
}

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

-Advertisement-
Play Games
更多相關文章
  • 什麼是多線程: 進程:正在運行的程式,QQ 360 ...... 線程:就是進程中一條執行程式的執行路徑,一個程式至少有一條執行路徑。(360中的殺毒 電腦體檢 電腦清理 同時運行的話就需要開啟多條路徑) 每個線程都有自己需要運行的內容,而這些內容可以稱為線程要執行的任務。 開啟多線程是為了同時運行 ...
  • 運行結果為: 程式細節: 一、#include <stdio.h> 指示和頭文件 #include 並不是C的語句。#表示這一行是在編譯器接手之前由C預處理器處理的語句。 ...
  • webbench簡介 webbench由C語言寫成的用於網站壓力測試的一個非常簡單的工具,它最多可以模擬30000個併發連接去進行測試。 webbench的安裝和使用可以自行百度,也可以過下這篇文章。 webbench執行流程 命令行解析 --> 構建HTTP請求包 --> 創建指定數量的工作進程 ...
  • 今天主要說下,配置在resources文件中的內容怎樣被spring boot所引用。 引用靜態模板的值 thymeleaf和spring boot的整合,及相關配置 根據springboot 推薦的格式,我們知道放在resources 都是一些資源,包括整個項目的配置啊 ,自定義配置啊 ,靜態資源 ...
  • python中定義函數時可以用必選參數、預設參數、可變參數、關鍵字參數和命名關鍵字參數,參數定義的順序必須是:必選參數、預設參數、可變參數、命名關鍵字參數和關鍵字參數 1.必選參數 必選參數就是位置參數,調用函數時必須傳入參數 2.預設參數 顧名思義預設參數就是函數有預設的參數可以不用傳值給參數 e ...
  • 在Servlet中添加一下代碼即可 ...
  • 1、第一個程式 輸出print輸出hello world 如果想在一行表達式中表達多行,只需要在表達式之間用逗號隔開就可以了print "hello" , "world" py2print ("hello" , "world") py3 輸入input/raw_inputpy2a = raw_inp ...
  • 1.三元運算 a=5 b=2 val = 1 if a>b else 2 print(val) 3.智能檢測 chardet 4.寫模式 ‘w’ 5.追加模式 ‘a’ 6.混合模式 f.open 要對應有f.close 7.文件操作的函數 1. fileno 返迴文件句柄在內核的索引值 網路編程是用 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...