1063. Set Similarity (25)

本文介绍了一种计算两个整数集合相似度的方法,并通过C++代码实现。利用set_intersection函数求交集,计算交集与并集元素的比例,得出集合相似度。

Given two sets of integers, the similarity of the sets is defined to be Nc/Nt*100%, where Nc is the number of distinct common numbers shared by the two sets, and Nt is the total number of distinct numbers in the two sets.  Your job is to calculate the similarity of any given pair of sets.

Input Specification:

Each input file contains one test case.  Each case first gives a positive integer N (<=50) which is the total number of sets.  Then N lines follow, each gives a set with a positive M (<=104) and followed by M integers in the range [0, 109].  After the input of sets, a positive integer K (<=2000) is given, followed by K lines of queries.  Each query gives a pair of set numbers (the sets are numbered from 1 to N).  All the numbers in a line are separated by a space.

Output Specification:

For each query, print in one line the similarity of the sets, in the percentage form accurate up to 1 decimal place.

Sample Input:
3
3 99 87 101
4 87 101 5 87
7 99 101 18 5 135 18 99
2
1 2
1 3
Sample Output:
50.0%
33.3%

 考察集合的应用,关键要知道用函数的使用

集合介绍:set集合容器实现了红黑树(Red-Black Tree)的平衡二叉检索树的数据结构,在插入数据时会自动调整二叉树的排列确保每个子树根节点的键值都大于左子树所有节点的键值,小于右子树所有节点的键值!

参考AC代码:

#include <iostream>
#include <algorithm>		//set_intersection 函数
#include <iomanip>
#include <iterator>		//inserter函数
#include <set>
using namespace std;

int main()
{
    int n,m,in;
    cin>>n;
    set<int> arr[n];
    int i,j;
    for(i=0;i<n;i++)
    {
        cin>>m;
		for(j=0;j<m;j++)
		{
			cin>>in;
			arr[i].insert(in);
		}
   }
   set<int> destination;
   int k,a,b,interSize,totalSize;
   cin>>k;
   for(i=0;i<k;i++)
   {
		cin>>a>>b;
		set_intersection(arr[a-1].begin(),arr[a-1].end(),arr[b-1].begin(),arr[b-1].end(),inserter(destination,destination.begin()));		//求集合交集
		interSize = destination.size();
		totalSize = arr[a-1].size()+arr[b-1].size()-interSize;
		destination.clear();

		cout<<fixed<<setprecision(1)<<((double)interSize/totalSize)*100.0<<"%"<<endl;
   }
    return 0;
}


主要对set_intersection函数作下简单的介绍:

这个函数是求集合的交集的

template <class InputIterator1, class InputIterator2, class OutputIterator>
  OutputIterator set_intersection (InputIterator1 first1, InputIterator1 last1,
                                   InputIterator2 first2, InputIterator2 last2,
                                   OutputIterator result)
{
  while (first1!=last1 && first2!=last2)
  {
    if (*first1<*first2) ++first1;
    else if (*first2<*first1) ++first2;
    else {
      *result = *first1;
      ++result; ++first1; ++first2;
    }
  }
  return result;
}


 

下面来一个简单的例子作为理解:

// set_intersection example
#include <iostream>     // std::cout
#include <algorithm>    // std::set_intersection, std::sort
#include <vector>       // std::vector

int main () {
  int first[] = {5,10,15,20,25};
  int second[] = {50,40,30,20,10};
  std::vector<int> v(10);                      // 0  0  0  0  0  0  0  0  0  0
  std::vector<int>::iterator it;

  std::sort (first,first+5);     //  5 10 15 20 25
  std::sort (second,second+5);   // 10 20 30 40 50

  it=std::set_intersection (first, first+5, second, second+5, v.begin());
                                               // 10 20 0  0  0  0  0  0  0  0
  v.resize(it-v.begin());                      // 10 20

  std::cout << "The intersection has " << (v.size()) << " elements:\n";
  for (it=v.begin(); it!=v.end(); ++it)
    std::cout << ' ' << *it;
  std::cout << '\n';

  return 0;
}
 


 

Output:

The intersection has 2 elements:
 10 20


 

<think>好的,我现在要帮用户解决如何设置字体大小的问题。用户提供的代码是使用Matplotlib绘图的Python函数。我需要仔细看看代码,然后思考如何调整字体大小。 首先,用户给出的函数是draw_sim,里面用到了fig.add_subplot创建了一个子图,然后设置了x轴、y轴的标签和标题。用户的问题是如何设置这些元素的字体大小。 我记得在Matplotlib中,设置字体大小通常有两种方法:一种是通过全局设置,比如修改rcParams;另一种是在具体的元素上设置,比如在set_xlabel时指定fontsize参数。用户可能希望局部调整,所以应该优先考虑后者。 首先看ax.set_xlabel,这里可以添加fontsize参数,例如ax.set_xlabel('...', fontsize=12)。同样,set_ylabel和set_title也是一样的道理。标题可能还需要调整字体大小,比如fontsize=14。 另外,y轴的刻度标签是用ax.set_yticklabels设置的,这里的列表推导式格式化了标签,但当前没有指定字体大小。可以在set_yticklabels里加入fontsize参数,或者在之前用tick_params来设置。比如,ax.tick_params(axis='both', labelsize=10) 这样同时调整x和y轴的刻度标签大小。 也有可能用户希望调整全局的字体设置,比如在plt.figure之后使用rcParams,比如plt.rcParams['font.size'] = 12。但用户可能只需要调整当前图的字体,所以局部设置更合适。 检查代码中的各个部分:xlabel、ylabel、title、以及tick labels。每个地方都需要添加fontsize参数。例如: ax.set_xlabel('Number of Hash Functions', fontsize=12) ax.set_ylabel('Jaccard Similarity with Naive Method', fontsize=12) ax.set_title('Correctness vs. Number of Hash Functions', fontsize=14) 然后,在设置yticklabels的时候,可以添加fontsize: ax.set_yticklabels(['...'], fontsize=10) 或者,使用tick_params来统一设置: ax.tick_params(axis='both', which='major', labelsize=10) 这样会更简洁,同时设置x和y轴的刻度标签大小。 另外,图例(如果有的话)也需要设置字体大小,但用户当前的代码中没有图例,所以可能不需要考虑这点。 总结一下,用户需要修改的地方包括:x轴标签、y轴标签、标题的字体大小,以及刻度标签的字体大小。可以通过在每个设置函数中添加fontsize参数,或者使用tick_params来调整刻度标签的大小。</think>要设置Matplotlib图表中的字体大小,可以通过以下方法逐步修改代码: $$修改后代码:$$ ```python def draw_sim(sims, h_num): fig = plt.figure(dpi=600) ax = fig.add_subplot(111) # 设置全局字体(可选) plt.rcParams['font.size'] = 10 # 默认字体大小 # 绘制曲线 ax.plot(h_num, sims) # 设置坐标轴标签及字体 ax.set_xlabel('Number of Hash Functions', fontsize=12) # X轴标签 ax.set_yaxlabel('Jaccard Similarity with Naive Method', fontsize=12) # Y轴标签 # 设置标题及字体 ax.set_title('Correctness vs. Number of Hash Functions', fontsize=14, pad=20) # pad调整标题间距 # 设置刻度值字体 ax.tick_params(axis='both', which='major', labelsize=10) # 同时设置x/y轴刻度 # 格式化百分比标签 vals = ax.get_yticks() ax.set_yticklabels(['{:,.1%}'.format(x) for x in vals], fontsize=10) # 单独设置y轴 plt.show() ``` $$参数说明表$$ | 组件 | 关键参数 | 推荐值 | 作用域 | |------------------|-------------------------|--------|------------------| | 全局字体 | plt.rcParams['font.size'] | 10 | 影响所有未单独设置的文本 | | 坐标轴标签 | fontsize | 12 | 仅当前轴标签 | | 图表标题 | fontsize | 14 | 仅标题文本 | | 刻度数值 | labelsize | 10 | 当前轴刻度值 | | 百分比标签 | fontsize | 10 | 特定格式化标签 | $$扩展设置方法$$ 1. **动态调整公式字体**: ```python plt.rcParams['mathtext.fontset'] = 'stix' # 设置数学公式字体 plt.rcParams['mathtext.default'] = 'regular' # 设置数学公式样式 ``` 2. **使用样式表批量设置**: ```python plt.style.use('seaborn-paper') # 自动应用预定义样式 plt.rcParams.update({'font.size': 12}) # 覆盖样式表设置 ``` 3. **Latex公式字体**(需安装LaTeX环境): ```python plt.rcParams['text.usetex'] = True # 启用LaTeX渲染 plt.rcParams['text.latex.preamble'] = r'\usepackage{amsmath}' # 添加宏包 ``` 建议优先使用组件级参数设置(如`fontsize=12`),避免全局设置影响其他图表。对于学术论文插图,推荐X/Y轴标签使用12pt,标题使用14pt,刻度标签使用10pt。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值