CCF-CSP 33-2 相似度计算(jaccard)【C++】考点:STL容器(set/map)

题目

TUOJhttps://sim.csp.thusaac.com/contest/33/problem/1

思路参考:202403(第33次)CCF CSP真题202403-1,2讲解_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1PUvxefEJr/

思路

核心思路:这题如果会用STL容器(set/map)很容易拿满

代码

可以让AI总结一下代码逻辑

  1. 归一化处理 :读取两组单词序列,利用 transform 函数将所有单词转换为小写,以实现忽略大小写的匹配。
  2. 去重与计数
    • 使用 map<string, int> mpA 存储第一组单词,确保集合 A 中的单词唯一。
    • 使用 map<string, int> mpB 存储第二组单词,确保集合 B 中的单词唯一。
  3. 计算交集 :在处理第二组单词时,利用 mpA.count(s) 检查当前(去重后的)单词是否存在于集合 A 中,统计交集大小 jiaoji。
  4. 计算并集并输出
    • 输出交集大小 jiaoji。
    • 根据容斥原理,输出并集大小:mpA.size() + mpB.size() - jiaoji。
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define endl '\n'
map<string,int>mpA, mpB;

void solve(){
	int n,m; cin>>n>>m;
	int jiaoji=0;
	for(int i=0;i<n;i++){
		string s; cin>>s;
		// for(int j=0;j<s.size();j++)
		// 	if(isupper(s[j])) s[j]=tolower(s[j]); //tolower 不会改原来的字符 
		transform(s.begin(),s.end(),s.begin(),::tolower); //直接字符串转小写 transform(源起始, 源结束, 目标起始, 一元操作函数);
		if(mpA[s]) continue; 
		mpA[s]=1;
	} 
	for(int i=0;i<m;i++){
		string s; cin>>s;
		transform(s.begin(),s.end(),s.begin(),::tolower);
		if(mpB[s]) continue; //避免重复计算交集 
		mpB[s]=1;
//		if(mpA[s]==1) jiaoji++; //交集  //warn:如果键 s 不存在,调用 mpA[s] 会自动在 map 中插入该键,并将值初始化为 0
 		if(mpA.count(s)==1) jiaoji++; 
	} 
	cout<<jiaoji<<endl;
	cout<<mpA.size()+mpB.size()-jiaoji<<endl;
	
} 

int main(){
	ios::sync_with_stdio(0),cin.tie(0);
	solve();
	return 0;
}
相关推荐
海清河晏1118 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
2601_961875248 小时前
法考考试时间安排及科目|时间表|资料已整理
开发语言·c#·inverted-index·suffix-tree·sstable·r-tree·lsm-tree
AI科技星8 小时前
数术工坊第八卷:算力革命
c语言·开发语言·网络·量子计算·agi
Frank学习路上8 小时前
【C++】面试:关键字与语法特性
c++·面试
geovindu8 小时前
go: Generators Pattern
开发语言·后端·设计模式·golang·生成器模式
IronMurphy9 小时前
【算法五十七】146. LRU 缓存
算法·缓存
Irissgwe9 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列
凌波粒9 小时前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle9 小时前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
码云骑士9 小时前
13-列表append的底层真相(上)-listobject源码中的预分配策略
开发语言·python