l2-005 集合相似度 (25 分)
給定兩個整數集合,它們的相似度定義為:nc/nt×100%。其中nc是兩個集合都有的不相等整數的個數,nt是兩個集合一共有的不相等整數的個數。你的任務就是計算任意一對給定集合的相似度。
輸入第一行給出乙個正整數n(≤50),是集合的個數。隨後n行,每行對應乙個集合。每個集合首先給出乙個正整數m(≤104),是集合中元素的個數;然後跟m個[0,109]區間內的整數。
之後一行給出乙個正整數k(≤2000),隨後k行,每行對應一對需要計算相似度的集合的編號(集合從1到n編號)。數字間以空格分隔。
對每一對需要計算的集合,在一行中輸出它們的相似度,為保留小數點後2位的百分比數字。
3
3 99 87 101
4 87 101 5 87
7 99 101 18 5 135 18 99
21 2
1 3
50.00%
33.33%
題目考察的是stl中的set的使用, 其中有兩個坑點(其實正常做能拿到21分)
for (it = s[a].begin(); it != s[a].end(); it++)
for (it = s[b].begin(); it != s[b].end(); it++)
這樣最後nt就應該是st.size()了.
正確方法應該是把nt初始化為s[b].size(), 這樣只要找a集合當中沒有在b**現過的(獨有的), ++就好了.
之前一直不知道她倆之間有速度差別...
比如:set.count(5); 和 count(set.begin(), set.end(), 5); 在速度上會有很大的差異....
以後我要多加注意這一點......
L2 005 集合相似度
給定兩個整數集合,它們的相似度定義為 nc nt 100 其中nc是兩個集合都有的不相等整數的個數,nt是兩個集合一共有的不相等整數的個數。你的任務就是計算任意一對給定集合的相似度。輸入格式 輸入第一行給出乙個正整數n 50 是集合的個數。隨後n行,每行對應乙個集合。每個集合首先給出乙個正整數m 1...
L2 005 集合相似度
給定兩個整數集合,它們的相似度定義為 nc nt 100 其中nc是兩個集合都有的不相等整數的個數,nt是兩個集合一共有的不相等整數的個數。你的任務就是計算任意一對給定集合的相似度。輸入第一行給出乙個正整數n 50 是集合的個數。隨後n行,每行對應乙個集合。每個集合首先給出乙個正整數m 104 是集...
L2 005 集合相似度
時間限制 400 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 陳越 給定兩個整數集合,它們的相似度定義為 nc nt 100 其中nc是兩個集合都有的不相等整數的個數,nt是兩個集合一共有的不相等整數的個數。你的任務就是計算任意一對給定集合的相似度。...