#5050. Problem 1. All Pairs Similarity
Problem 1. All Pairs Similarity
Problem 1. All Pairs Similarity
USACO 2024 December Contest, Platinum
注意:本题的内存限制为 512MB,通常限制的 2 倍。
Farmer John 的 ()头奶牛都被分配了一个长度为 的非全零位串()。不同的奶牛可能被分配到相同的位串。
两个位串的 Jaccard 相似度定义为它们的按位与的结果中 的数量除以它们的按位或的结果中 的数量。例如,位串 和 的 Jaccard 相似度为 。
对于每头奶牛,输出她的位串与每头奶牛(包括她自己)的位串的 Jaccard 相似度之和,对 取模。具体地说,如果总和等于一个有理数 ,其中 和 是互质的整数,则输出范围 内的唯一整数 ,使得 被 整除。
输入格式(从终端 / 标准输入读入):
输入的第一行包含 和 。
以下 行每行包含一个整数 ,表示一头奶牛分配到了 的 位二进制表示。
输出格式(输出至终端 / 标准输出):
对于每头奶牛输出一行,包含所求的总和,对 取模。
输入样例:
4 2 1 1 2 3
输出样例:
500000006 500000006 500000005 500000006
奶牛们分配到了以下的位串:$[\texttt{01}, \texttt{01}, \texttt{10}, \texttt{11}]$。
对于第一头奶牛,总和为 $\text{sim}(1,1)+\text{sim}(1,1)+\text{sim}(1,2)+\text{sim}(1,3)=1+1+0+1/2\equiv 500000006\pmod{10^9+7}$。
第二头奶牛的位串与第一头奶牛相同,所以她的总和也与第一头奶牛相同。
对于第三头奶牛,总和为 $\text{sim}(2,1)+\text{sim}(2,1)+\text{sim}(2,2)+\text{sim}(2,3)=0+0+1+1/2\equiv 500000005\pmod{10^9+7}$。
测试点性质: 测试点 2-15:对于每一个 有两个测试点。
供题:Benjamin Qi