博客
关于我
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 数据库备份及ibdata1的瘦身
    查看>>
    MySQL 数据库备份种类以及常用备份工具汇总
    查看>>
    mysql 数据库存储引擎怎么选择?快来看看性能测试吧
    查看>>
    MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
    查看>>
    MySQL 数据库的高可用性分析
    查看>>
    MySQL 数据库设计总结
    查看>>
    Mysql 数据库重置ID排序
    查看>>
    Mysql 数据类型一日期
    查看>>
    MySQL 数据类型和属性
    查看>>
    mysql 敲错命令 想取消怎么办?
    查看>>
    Mysql 整形列的字节与存储范围
    查看>>
    mysql 断电数据损坏,无法启动
    查看>>
    MySQL 日期时间类型的选择
    查看>>
    Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
    查看>>
    MySQL 是如何加锁的?
    查看>>
    MySQL 是怎样运行的 - InnoDB数据页结构
    查看>>
    mysql 更新子表_mysql 在update中实现子查询的方式
    查看>>
    MySQL 有什么优点?
    查看>>
    mysql 权限整理记录
    查看>>
    mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
    查看>>