博客
关于我
L2-005 集合相似度 (25 分)
阅读量:569 次
发布时间:2019-03-09

本文共 1428 字,大约阅读时间需要 4 分钟。

为了解决这个问题,我们需要计算两个集合之间的相似度。集合相似度通常是指两个集合中元素的重叠程度,或者说它们的交集占总元素数的比例。我们可以使用C++来实现这一点。

方法思路

  • 读取输入数据:首先读取集合的总数N,然后读取每个集合的元素数目及其元素。
  • 存储集合元素:对于每个集合,去重并存储其元素。
  • 处理查询:对于每个查询,读取两个集合的位置,计算它们的交集元素数目,然后计算相似度。
  • 计算相似度:相似度计算为交集元素数目占总元素数的比例,结果保留两位小数。
  • 解决代码

    #include 
    #include
    #include
    #include
    using namespace std;int main() { istringstream iss(input_data); vector
    > sets; // 读取集合数量N int N; iss >> N; for (int i = 0; i < N; ++i) { // 读取当前集合的元素数目K int K; iss >> K; unordered_set
    current_set; for (int j = 0; j < K; ++j) { int num; iss >> num; current_set.insert(num); } sets.push_back(current_set); } // 读取查询次数M int M; iss >> M; for (int m = 0; m < M; ++m) { int pos1, pos2; iss >> pos1 >> pos2; unordered_set
    & s1 = sets[pos1]; unordered_set
    & s2 = sets[pos2]; // 计算交集元素个数 unordered_set
    intersection; for (int num : s1) { if (s2.count(num)) { intersection.insert(num); } } int same = intersection.size(); int total = s1.size() + s2.size() - same; double similarity = (same * 100.0) / total; printf("%.2lf%%\n", similarity); } return 0;}

    代码解释

  • 读取输入数据:使用istringstream读取输入数据,逐个处理每个集合的元素。
  • 存储集合元素:使用unordered_set去重存储每个集合的元素。
  • 处理查询:对于每个查询,读取两个集合的位置,计算它们的交集元素数目。
  • 计算相似度:计算交集元素数目占总元素数的比例,结果保留两位小数并输出。
  • 这个方法确保了我们能够高效且准确地计算集合之间的相似度。

    转载地址:http://ieipz.baihongyu.com/

    你可能感兴趣的文章
    mysql 索引类型以及创建
    查看>>
    MySQL 索引连环问题,你能答对几个?
    查看>>
    Mysql 索引问题集锦
    查看>>
    Mysql 纵表转换为横表
    查看>>
    mysql 编译安装 window篇
    查看>>
    mysql 网络目录_联机目录数据库
    查看>>
    MySQL 聚簇索引&&二级索引&&辅助索引
    查看>>
    Mysql 脏页 脏读 脏数据
    查看>>
    mysql 自增id和UUID做主键性能分析,及最优方案
    查看>>
    Mysql 自定义函数
    查看>>
    mysql 行转列 列转行
    查看>>
    Mysql 表分区
    查看>>
    mysql 表的操作
    查看>>
    mysql 视图,视图更新删除
    查看>>
    MySQL 触发器
    查看>>
    mysql 让所有IP访问数据库
    查看>>
    mysql 记录的增删改查
    查看>>
    MySQL 设置数据库的隔离级别
    查看>>
    MySQL 证明为什么用limit时,offset很大会影响性能
    查看>>
    Mysql 语句操作索引SQL语句
    查看>>