當今世界,網路已經無處不在了,小度熊由於犯了錯誤,當上了度度公司的網路管理員,他手上有大量的 ip列表,小度熊想知道在某個固定的子網掩碼下,有多少個網路位址。網路位址等於子網掩碼與 ip 位址按位進行與運算後的結果,例如:
第一行包含乙個整數t,(1≤t≤50)代表測試資料的組數,
接下來t組測試資料。每組測試資料報含若干行,
第一行兩個正整數n(1≤n≤1000,1≤m≤50),m。接下來n行,每行乙個字串,代表乙個 ip 位址,
再接下來m行,每行乙個字串代表子網掩碼。ip 位址和子網掩碼均採用 a.b.c.d的形式,其中a、b、c、d均為非負整數,且小於等於255。
對於每組測試資料,輸出兩行:
第一行輸出: 「case #i:」 。i代表第i組測試資料。
第二行輸出測試資料的結果,對於每組資料中的每乙個子網掩碼,輸出在此子網掩碼下的網路位址的數量。
2 5 2
192.168.1.0
192.168.1.101
192.168.2.5
192.168.2.7
202.14.27.235
255.255.255.0
255.255.0.0
4 2
127.127.0.1
10.134.52.0
127.0.10.1
10.134.0.2
235.235.0.0
1.57.16.0
case #1:
3 2
case #2: 3 4
#include
#include
#include
int comp(const
void*a,const
void*b)
int main()
printf("case #%d:\n", x);
for(int i=0; iunsigned
int subaddr;
scanf("%d.%d.%d.%d", &a, &b, &c, &d);
subaddr = (a<<24)+(b<<16)+(c<<8)+d;
for(int j=0; jsizeof(unsigned
int),comp);
int cnt = 1;
for(int j=1; jif(net[j] != net[j-1])
cnt++;
}printf("%d\n", cnt);}}
return
0;}
IP聚合 百度之星(與運算)
problem description 當今世界,網路已經無處不在了,小度熊由於犯了錯誤,當上了度度公司的網路管理員,他手上有大量的 ip列表,小度熊想知道在某個固定的子網掩碼下,有多少個網路位址。網路位址等於子網掩碼與 ip 位址按位進行與運算後的結果,例如 子網掩碼 a.b.c.d input ...
百度之星 資格賽 IP聚合
保持著也不知道什麼情懷,覺得到現在才能發出來。這道題做完之後看了其他人的 然後再看我的,不得不說,真是幼稚的很,尤其是輸入這一塊,都什麼跟什麼啊。但相較於之前來說,不像以前慌張了,學會先思考再去寫 明白了函式的一些用處與含義。我知道乙個大四的老狗說這種話倒還真是夠沒面子的,但希望自己每天都在成長。你...
2018百度之星初賽1003
problem description 度度熊有一張紙條和一把剪刀。紙條上依次寫著 n 個數字,數字只可能是 0 或者 1。度度熊想在紙條上剪 k 刀 每一刀只能剪在數字和數字之間 這樣就形成了 k 1 段。他再把這 k 1 段按一定的順序重新拼起來。不同的剪和接的方案,可能會得到不同的結果。度度熊...