博客
关于我
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 InnoDB引擎的锁机制详解
    查看>>
    Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
    查看>>
    mysql InnoDB数据存储引擎 的B+树索引原理
    查看>>
    mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
    查看>>
    mysql problems
    查看>>
    MySQL replace函数替换字符串语句的用法(mysql字符串替换)
    查看>>
    mysql workbench6.3.5_MySQL Workbench
    查看>>
    MySQL Workbench安装教程以及菜单汉化
    查看>>
    MySQL Xtrabackup 安装、备份、恢复
    查看>>
    mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
    查看>>
    MySQL _ MySQL常用操作
    查看>>
    MySQL – 导出数据成csv
    查看>>
    MySQL —— 在CentOS9下安装MySQL
    查看>>
    mysql 不区分大小写
    查看>>
    mysql 两列互转
    查看>>
    MySQL 中开启二进制日志(Binlog)
    查看>>
    MySQL 中文问题
    查看>>
    MySQL 中日志的面试题总结
    查看>>
    MySQL 中随机抽样:order by rand limit 的替代方案
    查看>>
    MySQL 为什么需要两阶段提交?
    查看>>