luogu1196 銀河英雄傳說

2021-08-18 04:20:53 字數 1760 閱讀 3386

題目描述

公元五八○一年,地球居民遷至金牛座α第二行星,在那裡發表銀河聯邦創立宣言,同年改元為宇宙歷元年,並開始向銀河系深處拓展。

宇宙歷七九九年,銀河系的兩大軍事集團在巴公尺利恩星域爆發戰爭。泰山壓頂集團派宇宙艦隊司令萊因哈特率領十萬餘艘戰艦出征,氣吞山河集團點名將楊威利組織麾下三萬艘戰艦迎敵。

楊威利擅長排兵布陣,巧妙運用各種戰術屢次以少勝多,難免恣生驕氣。在這次決戰中,他將巴公尺利恩星域戰場劃分成30000列,每列依次編號為1, 2, …,30000。之後,他把自己的戰艦也依次編號為1, 2, …, 30000,讓第i號戰艦處於第i列(i = 1, 2, …, 30000),形成「一字長蛇陣」,誘敵深入。這是初始陣形。當進犯之敵到達時,楊威利會多次發布合併指令,將大部分戰艦集中在某幾列上,實施密集攻擊。合併指令為m i j,含義為第i號戰艦所在的整個戰艦佇列,作為乙個整體(頭在前尾在後)接至第j號戰艦所在的戰艦佇列的尾部。顯然戰艦佇列是由處於同一列的乙個或多個戰艦組成的。合併指令的執行結果會使佇列增

大。 然而,老謀深算的萊因哈特早已在戰略上取得了主動。在交戰中,他可以通過龐大的情報網路隨時監聽楊威利的艦隊調動指令。

在楊威利發布指令調動艦隊的同時,萊因哈特為了及時了解當前楊威利的戰艦分布情況,也會發出一些詢問指令:c i j。該指令意思是,詢問電腦,楊威利的第i號戰艦與第j號戰艦當前是否在同一列中,如果在同一列中,那麼它們之間布置有多少戰艦。

作為乙個資深的高階程式設計員,你被要求編寫程式分析楊威利的指令,以及回答萊因哈特的詢問。

最終的決戰已經展開,銀河的歷史又翻過了一頁……

輸入輸出格式

輸入格式:

輸入檔案galaxy.in的第一行有乙個整數t(1<=t<=500,000),表示總共有t條指令。

以下有t行,每行有一條指令。指令有兩種格式:

m i j :i和j是兩個整數(1<=i , j<=30000),表示指令涉及的戰艦編號。該指令是萊因哈特竊聽到的楊威利發布的艦隊調動指令,並且保證第i號戰艦與第j號戰艦不在同一列。

c i j :i和j是兩個整數(1<=i , j<=30000),表示指令涉及的戰艦編號。該指令是萊因哈特發布的詢問指令。

輸出格式:

輸出檔案為galaxy.out。你的程式應當依次對輸入的每一條指令進行分析和處理:

如果是楊威利發布的艦隊調動指令,則表示艦隊排列發生了變化,你的程式要注意到這一點,但是不要輸出任何資訊;

如果是萊因哈特發布的詢問指令,你的程式要輸出一行,僅包含乙個整數,表示在同一列上,第i 號戰艦與第j 號戰艦之間布置的戰艦數目。如果第i 號戰艦與第j號戰艦當前不在同一列上,則輸出-1。

輸入輸出樣例

輸入樣例#1:

4m 2 3

c 1 2

m 2 4

c 4 2

輸出樣例#1:-11

說明【樣例說明】

戰艦位置圖:**中阿拉伯數字表示戰艦編號

用自帶庫的abs 直接輸出可能有問題,我在洛谷爆0了多次

一開始還忘寫路徑壓縮了,導致有幾個點超時

#include#include#define n 33000

using namespace std;

inline int read()

return x;

}int fa[n],t,x,y,size[n],s[n];//s[i]表示 i前面有多少戰艦 size表示這個連通塊有多少個戰艦

inline int find(int x)

int main()else

} return 0;

}

Luogu P1196 銀河英雄傳說

我們考慮用並查集來維護戰艦的情況。同時,我們用乙個 d 陣列來記錄 x 與 fa x 之間的距離。再用 size 陣列記錄戰艦當前所在列的戰艦數。易知兩艘在同一列的戰艦之間隔著 d x d y 1 艘戰艦。include define n 30010 using namespace std int ...

P1196 銀河英雄傳說

這題真的很經典,我wa了三次,最後一次才ac 因為這道題是很有技術含量的,能自己寫出來真的很厲害 不是在誇自己 如果只是粗略的去看題解或者抄題解 倒是可以用來矇騙自己 那這道題就失去意義了。下面的 每一句話,都是值得深刻推敲的。舉幾個例子 int find int x 這裡就不能直接寫par x f...

洛谷 1196 銀河英雄傳說

傳送門 寫題一時wa了時間不多了計畫還沒完成先放下去寫道水題好像是正確的選擇。對每個點記錄它到當前代表元的距離,初始都為0 到自己 合併時之前代表元的距離就等於它要合併的那個集合的size。路徑壓縮時先加上父親到代表元的距離,再把父親換成代表元。twenty include include incl...