L2-005 集合相似度 (25分)

让人想犯罪 __ 提交于 2020-02-25 22:37:43
#include <stdio.h>
#include <set>
#include <algorithm>
#include <iostream>
using namespace std;

const int si=51;
set<int> st[si];



int main()
{
    int N,K,M;
    cin>>N;
    for(int i=1;i<=N;i++)
    {
        cin>>M;
        int x;
        for(int j=0;j<M;j++)
        {
            cin>>x;
            st[i].insert(x);
        }
    }
    cin>>K;
    for(int i=0;i<K;i++)
    {
        set <int> U,I;
        int a,b;
        cin>>a>>b;
        set_union(st[a].begin(),st[a].end(),st[b].begin(),st[b].end(),inserter(U,U.begin()));
        set_intersection(st[a].begin(),st[a].end(),st[b].begin(),st[b].end(),inserter(I,I.begin()));
        printf("%.2f%%\n",I.size()*100.0/U.size());
    }



}

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!