大模擬 Major

題目來源:2025 Wuhan University of Technology Programming Contest

比賽鏈接:Dashboard - 2025 Wuhan University of Technology Programming Contest - Codeforces

題目大意:

模擬 16 支隊伍的瑞士輪比賽結果,規則太多,直接上題面吧。

Solution:

依題意模擬,將每一輪勝負場次相同的隊伍放進一個 vector 里,按照規則排序。

總之就是很暴力。。。

不過好在這題打起來并沒有看上去那么復雜,規劃好每個子函數的功能,思路還是非常清晰的,很快就能碼完。

(其實代碼可以更短,但為了體現每一步清楚的思路,多打一點也沒什么,模擬題就是要求穩)

Code:

#include<cstdio>
#include<cstring>
#include<vector>
#include<algorithm>
using namespace std;int win[20][20],race[20][20],vis[20],b[10];vector<int> t1,t2,t3;struct Team
{int winned,losed,sum;vector<int> rival;
}a[20];void battle(int x,int y)
{race[x][y] = race[y][x] = 1;if(win[x][y]) ++ a[x].winned,++ a[y].losed;else ++ a[x].losed,++ a[y].winned;a[x].rival.push_back(y);a[y].rival.push_back(x);return;
}void calc()
{for (int i = 1;i <= 16;++ i){int tmp = 0;for (auto j : a[i].rival)tmp += a[j].winned - a[j].losed;a[i].sum = tmp;}return;
}int cmp(int x,int y)
{if(a[x].sum == a[y].sum) return x < y;else return a[x].sum > a[y].sum;
}void round1()
{for (int i = 1;i <= 8;++ i) battle(i,i + 8);t1.clear();t2.clear();for (int i = 1;i <= 16;++ i)if(a[i].winned == 1) t1.push_back(i);else t2.push_back(i);calc();sort(t1.begin(),t1.end(),cmp);sort(t2.begin(),t2.end(),cmp);return;
}void round2()
{memset(vis,0,sizeof vis);for (auto i : t1){if(vis[i]) continue;for (auto it = t1.rbegin();it != t1.rend();++ it){int j = *it;if(vis[j]) continue;if(race[i][j]) continue;battle(i,j);vis[i] = vis[j] = 1;break;}}    for (auto i : t2){if(vis[i]) continue;for (auto it = t2.rbegin();it != t2.rend();++ it){int j = *it;if(vis[j]) continue;if(race[i][j]) continue;battle(i,j);vis[i] = vis[j] = 1;break;}}t1.clear();t2.clear();t3.clear();for (int i = 1;i <= 16;++ i)if(a[i].winned == 2) t1.push_back(i);else if(a[i].winned == 1) t2.push_back(i);else t3.push_back(i);calc();sort(t1.begin(),t1.end(),cmp);sort(t2.begin(),t2.end(),cmp);sort(t3.begin(),t3.end(),cmp);return;
}void round3()
{memset(vis,0,sizeof vis);for (auto i : t1){if(vis[i]) continue;for (auto it = t1.rbegin();it != t1.rend();++ it){int j = *it;if(vis[j]) continue;if(race[i][j]) continue;battle(i,j);vis[i] = vis[j] = 1;break;}}    for (auto i : t2){if(vis[i]) continue;for (auto it = t2.rbegin();it != t2.rend();++ it){int j = *it;if(vis[j]) continue;if(race[i][j]) continue;battle(i,j);vis[i] = vis[j] = 1;break;}}for (auto i : t3){if(vis[i]) continue;for (auto it = t3.rbegin();it != t3.rend();++ it){int j = *it;if(vis[j]) continue;if(race[i][j]) continue;battle(i,j);vis[i] = vis[j] = 1;break;}}t1.clear();t2.clear();t3.clear();for (int i = 1;i <= 16;++ i)if(a[i].winned == 2 && a[i].losed == 1) t1.push_back(i);else if(a[i].winned == 1 && a[i].losed == 2) t2.push_back(i);calc();sort(t1.begin(),t1.end(),cmp);sort(t2.begin(),t2.end(),cmp);return;
}void run()
{int flag = 0;if(!race[b[1]][b[6]] && !race[b[2]][b[5]] && !race[b[3]][b[4]])battle(b[1],b[6]),battle(b[2],b[5]),battle(b[3],b[4]),flag = 1;if(flag) return;if(!race[b[1]][b[6]] && !race[b[2]][b[4]] && !race[b[3]][b[5]])battle(b[1],b[6]),battle(b[2],b[4]),battle(b[3],b[5]),flag = 1;if(flag) return;if(!race[b[1]][b[5]] && !race[b[2]][b[6]] && !race[b[3]][b[4]])battle(b[1],b[5]),battle(b[2],b[6]),battle(b[3],b[4]),flag = 1;if(flag) return;if(!race[b[1]][b[5]] && !race[b[2]][b[4]] && !race[b[3]][b[6]])battle(b[1],b[5]),battle(b[2],b[4]),battle(b[3],b[6]),flag = 1;if(flag) return;if(!race[b[1]][b[4]] && !race[b[2]][b[6]] && !race[b[3]][b[5]])battle(b[1],b[4]),battle(b[2],b[6]),battle(b[3],b[5]),flag = 1;if(flag) return;if(!race[b[1]][b[4]] && !race[b[2]][b[5]] && !race[b[3]][b[6]])battle(b[1],b[4]),battle(b[2],b[5]),battle(b[3],b[6]),flag = 1;if(flag) return;if(!race[b[1]][b[6]] && !race[b[2]][b[3]] && !race[b[4]][b[5]])battle(b[1],b[6]),battle(b[2],b[3]),battle(b[4],b[5]),flag = 1;if(flag) return;if(!race[b[1]][b[5]] && !race[b[2]][b[3]] && !race[b[4]][b[6]])battle(b[1],b[5]),battle(b[2],b[3]),battle(b[4],b[6]),flag = 1;if(flag) return;if(!race[b[1]][b[3]] && !race[b[2]][b[6]] && !race[b[4]][b[5]])battle(b[1],b[3]),battle(b[2],b[6]),battle(b[4],b[5]),flag = 1;if(flag) return;if(!race[b[1]][b[3]] && !race[b[2]][b[5]] && !race[b[4]][b[6]])battle(b[1],b[3]),battle(b[2],b[5]),battle(b[4],b[6]),flag = 1;if(flag) return;if(!race[b[1]][b[4]] && !race[b[2]][b[3]] && !race[b[5]][b[6]])battle(b[1],b[4]),battle(b[2],b[3]),battle(b[5],b[6]),flag = 1;if(flag) return;if(!race[b[1]][b[3]] && !race[b[2]][b[4]] && !race[b[5]][b[6]])battle(b[1],b[3]),battle(b[2],b[4]),battle(b[5],b[6]),flag = 1;if(flag) return;if(!race[b[1]][b[2]] && !race[b[3]][b[6]] && !race[b[4]][b[5]])battle(b[1],b[2]),battle(b[3],b[6]),battle(b[4],b[5]),flag = 1;if(flag) return;if(!race[b[1]][b[2]] && !race[b[3]][b[5]] && !race[b[4]][b[6]])battle(b[1],b[2]),battle(b[3],b[5]),battle(b[4],b[6]),flag = 1;if(flag) return;if(!race[b[1]][b[2]] && !race[b[3]][b[4]] && !race[b[5]][b[6]])battle(b[1],b[2]),battle(b[3],b[4]),battle(b[5],b[6]),flag = 1;if(flag) return;
}void round4()
{memset(b,0,sizeof b);int cnt = 0;for (auto i : t1) b[++ cnt] = i;run();memset(b,0,sizeof b);cnt = 0;for (auto i : t2) b[++ cnt] = i;run();t1.clear();for (int i = 1;i <= 16;++ i)if(a[i].winned == 2 && a[i].losed == 2) t1.push_back(i);calc();sort(t1.begin(),t1.end(),cmp);return;
}void round5()
{memset(b,0,sizeof b);int cnt = 0;for (auto i : t1) b[++ cnt] = i;run();return;
}int main()
{for (int i = 1;i <= 15;++ i)for (int j = 1,op;j <= 16 - i;++ j)scanf("%d",&op),win[i][i + j] = op , win[i + j][i] = op ^ 1;round1();round2();round3();round4();round5();for (int i = 1;i <= 16;++ i) printf("%d %d\n",a[i].winned,a[i].losed);return 0;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/93603.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/93603.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/93603.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【手撕JAVA多線程】1.從設計初衷去看JAVA的線程操作

目錄 前言 概述 主動阻塞/喚醒 代碼示例 實現 為什么必須在同步塊中使用 計時等待是如何實現的 被動阻塞/喚醒 為什么要有被動阻塞/喚醒 實現&#xff08;鎖升級&#xff09; 前言 JAVA多線程相關的內容很多很雜&#xff0c;但工作中用到的頻率不高&#xff0c;用到…

UE5多人MOBA+GAS 46、制作龍卷風技能

文章目錄創建龍卷風GA創建蒙太奇創捷一系列GE添加數據表添加到角色中創建龍卷風GA GA_Tornado 添加標簽 // 龍卷風冷卻CRUNCH_API UE_DECLARE_GAMEPLAY_TAG_EXTERN(Ability_Tornado_Cooldown)// 通用技能傷害CRUNCH_API UE_DECLARE_GAMEPLAY_TAG_EXTERN(Ability_Generic_Dama…

如何在ubuntu下安裝libgpiod庫

以下是關于如何在ubuntu下安裝libgpiod庫的兩種安裝方式以及遇到ubuntu存在多個工具鏈導致編譯失敗的解決方法。如果想要自由選擇使用不同版本的libgpiod&#xff0c;可以選擇手動編譯安裝方式&#xff0c;系統安裝默認1.6.3版本(ubuntu22.04)。手動編譯安裝1、在github上下載要…

qt vs2019編譯QXlsx

1、安裝ActivePerl2、打開pro文件&#xff0c;直接編譯即可第一個簡單實例&#xff1a;#include "xlsxcellrange.h" #include "xlsxchart.h" #include "xlsxchartsheet.h" #include "xlsxdocument.h" #include "xlsxrichstring.h…

計算機存儲器分類和層次結構詳解

存儲器是計算機系統的核心部件之一&#xff0c;其核心功能是存儲程序&#xff08;指令&#xff09;和數據&#xff0c;是馮諾依曼體系結構“存儲程序”概念的物質基礎。它直接關系到計算機系統的性能、容量和成本。 存儲器核心內容總覽表分類維度存儲器層級技術實現速度容量成本…

通過rss訂閱小紅書,程序員將小紅書同步到自己的github主頁

title: 通過rss訂閱小紅書&#xff0c;程序員將小紅書同步到自己的github主頁 tags: 個人成長 categories:雜談最近在做一些新的嘗試&#xff0c;把文本的內容轉化為漫畫和圖片&#xff0c;方便大眾閱讀&#xff0c;恰好小紅書很適合分發這些內容&#xff0c;于是我開通了小紅書…

麒麟KylinOS V10-SP3 安裝FastGPT

1. 操作系統環境CPU&#xff1a;20核 Xeon(R) Platinum 8457C 內存&#xff1a;64GB GPU&#xff1a;4090 操作系統&#xff1a;KylinOS-V10-SP32. 安裝docker、docker-compose、fastgpt下載安裝docker、docker-compose1. 下載docker docker 下載地址&#xff1a; https://do…

前端/在vscode中創建Vue3項目

Contenthtml input元素添加css樣式使用js添加交互按鈕點擊提示輸入框字符計數使用 npm 來管理項目包安裝 Node.js初始化項目安裝依賴包創建一個基于 Vite 的 Vue 項目創建項目進入項目目錄安裝依賴調用代碼格式化工具啟動開發服務器在瀏覽器中訪問html input元素 <input ty…

HiSmartPerf使用WIFI方式連接Android機顯示當前設備0.0.0.0無法ping通!設備和電腦連接同一網絡,將設備保持亮屏重新嘗試

在使用HiSmartPerf使用WIFI方式連接Android機時&#xff0c;如果出現無法ping通0.0.0.0的情況&#xff0c;可以嘗試以下步驟解決問題&#xff1a;問了一下AI&#xff0c;給出的解答如下&#xff1a; 檢查網絡連接 &#xff1a;確保設備和電腦連接到同一局域網的Wi-Fi。可以在手…

SpringWeb是什么東西?

SpringWeb是個什么東西&#xff1f;SpringWeb是一個Java開發Web項目時的Web層框架。所謂Web層&#xff0c;就是直接和用戶打交道的框架&#xff0c;用戶(User)也就是顧客&#xff0c;顧客就是上帝&#xff0c;我們說是Web項目&#xff0c;通常也就是說B/S架構的項目&#xff0c…

docker+nginx+keepalived+openappsec+web ui+crowdsec部署安全代理

docker+nginx+keepalived+openappsec+web ui+crowdsec部署安全代理 一、環境介紹 二、基礎環境安裝 1、優化系統參數 2、安裝docker 3、創建容器網絡 4、安裝測試容器(可選) 三、安裝nginx 1、拉取鏡像 2、創建映射目錄 3、準備默認配置文件 4、證書文件準備 5、啟動nginx容器…

自動駕駛中安全相關機器學習功能的可靠性定義方法

摘要當前標準無法涵蓋高自動化駕駛中基于機器學習功能的安全需求。由于神經網絡的不透明性&#xff0c;一些自動駕駛功能無法按照 V 模型進行開發。這些功能需要對標準進行擴展。本文聚焦這一空白&#xff0c;為這類功能定義了功能可靠性&#xff0c;以幫助未來的標準控制基于機…

css實現圓角+邊框漸變+背景半透明

ui小姐姐經常搞一些花里胡哨的東西&#xff0c;圓角邊框漸變背景半透明&#xff0c;雖然每個都可以弄&#xff0c;但是合在一起真的不好弄&#xff0c;主要是因為通過border–image設置的邊框漸變&#xff0c;無法使用圓角&#xff0c;下面是自己搜索整理的一些可以的方案。 方…

tree組件(幾種不同分叉樹Vue3)

效果圖&#xff1a; 基礎樹組件&#xff08;本人博客里面有&#xff09; https://blog.csdn.net/xfy991127/article/details/140346861?spm1001.2014.3001.5501 下面是工作需求改造后 父組件 <template><div class"go-JJTree" id"tree-scroll&quo…

百度智能云x中科大腦:「城市智能體」如何讓城市更會思考

近日&#xff0c;2025中關村論壇系列活動——中關村人工智能與未來城市論壇在中關村國家自主創新示范區展示中心舉辦。論壇上&#xff0c;發布了應用范式創新升級成果、智能體產品、可信數據空間成果等。 中科大腦聯合百度智能云等伙伴共同打造并發布21個智能體產品&#xff0c…

在職老D滲透日記day16:sqli-labs靶場通關(第24關)二次注入 sqlmap自動注入沒跑出來。。。

5.24.2.sqlmap自動注入第一個&#xff1a;登錄頁面&#xff08;1&#xff09;pb抓取http頭POST /sqli-labs/Less-24/login.php HTTP/1.1 Host: 192.168.10.106 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:141.0) Gecko/20100101 Firefox/141.0 Accept: text/ht…

Fanuc機器人EtherCAT通訊配置詳解

1、EtherCAT簡介EtherCAT&#xff0c;這一基于以太網的現場總線系統&#xff0c;以其開放架構和高速性能著稱。CAT代表的是控制自動化技術&#xff08;Control Automation Technology&#xff09;的縮寫&#xff0c;彰顯了其在工業自動化領域的核心地位。作為確定性的工業以太網…

超酷炫的Three.js示例

今天寫一個超級酷炫的Three.js示例&#xff0c;以下是文件源代碼&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-sca…

從零開始大模型之實現GPT模型

從零開始大模型之從頭實現GPT模型1.大語言模型整體架構2 大語言的Transformer模塊2.1 層歸一化2.2 GELU激活函數2.3 前饋神經網絡2.4 快捷連接3 附錄3.1 anacondapython環境搭建1.數據預處理&#xff1a;原始數據進行詞元化&#xff0c;以及通過&#xff0c;依據詞匯表生成ID編…

[1Prompt1Story] 滑動窗口機制 | 圖像生成管線 | VAE變分自編碼器 | UNet去噪神經網絡

鏈接&#xff1a;https://github.com/byliutao/1Prompt1Story 這個項目是一個基于單個提示生成一致文本到圖像的模型。它在ICLR 2025會議上獲得了聚焦論文的地位。該項目提供了生成一致圖像的代碼、Gradio演示代碼以及基準測試代碼。 主要功能點: 使用單個提示生成一致的文本…