蓝桥杯练习系统(算法训练)ALGO-951 预备爷的悲剧

资源限制

内存限制:512.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s

问题描述

英语预备爷gzp是个逗(tu)比(hao),为了在即将到来的英语的quiz中不挂科,gzp废寝忘食复习英语附录单词表,俨然一场人间悲剧。不过上天有好生之德,上帝扔给了gzp一张纸,上面记载了将要考到的单词。不过gzp是个逗比,之前复习的东西全忘记了,所以他又要再来一次复习。不过已经知道了要考的单词,所以不需要复习单词表的所有页数。因此,现在需要你帮助他求出有多少页纸需要复习。他会告诉你每个单词会在哪几页出现,并且告诉你要考哪些单词,你只要告诉他答案就可以了。由于一个单词会出现在不同页上,只需要复习在最前面一页上的就可以了。

输入格式

第一行一个整数n,表示单词附录有n个单词。接下来n行每行一个小写字母组成的单词和一个整数,表示某一个单词和它所在的页数。接下来是一行整数m,表示要考m个单词,接下来m行小写字母组成的单词,表示要考到的单词。

输出格式

一个数,表示需要复习的页数。

样例输入

5

ab 1

ac 2

ab 2

ac 3

c 3

3

ab

ac

c

样例输出

3

数据规模和约定

0<=n,m<=100000,单词长度<=10。

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<map>
using namespace std;
const int N=100005;
map<string,int> word_map;
int num[N];
int main(){
	int n;
	cin>>n;
	for(int i=0;i<n;i++){
		string word;
		int a;
		cin>>word>>a;
		//只需要出现在最前面的页数
		if(word_map.count(word)==0) word_map[word]=a;//第一次出现
		else{//已经出现过了 
			if(word_map[word]>a) word_map[word]=a; 
		} 
	}
	int m;
	cin>>m;
	for(int i=0;i<m;i++){
		string word;
		cin>>word;
		num[i]=word_map[word];
	}
	//去重 
	sort(num,num+m);
	int ans=unique(num,num+m)-num;
	cout<<ans<<endl;
	return 0;
} 

思路:使用map存储单词和单词出现的最前面的页数,将要考的m个单词的页数存下来。当然,里面可能会有重复的页数,因此需要去重。也可以使用set来去重:

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<map>
#include<set>
using namespace std;
//const int N=100005;
map<string,int> word_map;
set<int> pages;
//int num[N];
int main(){
	int n;
	cin>>n;
	for(int i=0;i<n;i++){
		string word;
		int a;
		cin>>word>>a;
		//只需要出现在最前面的页数
		if(word_map.count(word)==0) word_map[word]=a;//第一次出现
		else{//已经出现过了 
			if(word_map[word]>a) word_map[word]=a; 
		} 
	}
	int m;
	cin>>m;
	for(int i=0;i<m;i++){
		string word;
		cin>>word;
//		num[i]=word_map[word];
		pages.insert(word_map[word]);
	}
//	//去重 
//	sort(num,num+m);
//	int ans=unique(num,num+m)-num;
//	cout<<ans<<endl;
	cout<<pages.size()<<endl;
	return 0;
} 
相关推荐
王老师青少年编程3 小时前
gesp(C++五级)(14)洛谷:B4071:[GESP202412 五级] 武器强化
开发语言·c++·算法·gesp·csp·信奥赛
DogDaoDao3 小时前
leetcode 面试经典 150 题:有效的括号
c++·算法·leetcode·面试··stack·有效的括号
Coovally AI模型快速验证4 小时前
MMYOLO:打破单一模式限制,多模态目标检测的革命性突破!
人工智能·算法·yolo·目标检测·机器学习·计算机视觉·目标跟踪
可为测控5 小时前
图像处理基础(4):高斯滤波器详解
人工智能·算法·计算机视觉
Milk夜雨5 小时前
头歌实训作业 算法设计与分析-贪心算法(第3关:活动安排问题)
算法·贪心算法
BoBoo文睡不醒5 小时前
动态规划(DP)(细致讲解+例题分析)
算法·动态规划
apz_end6 小时前
埃氏算法C++实现: 快速输出质数( 素数 )
开发语言·c++·算法·埃氏算法
仟濹6 小时前
【贪心算法】洛谷P1106 - 删数问题
c语言·c++·算法·贪心算法
CM莫问7 小时前
python实战(十五)——中文手写体数字图像CNN分类
人工智能·python·深度学习·算法·cnn·图像分类·手写体识别
sz66cm7 小时前
LeetCode刷题 -- 45.跳跃游戏 II
算法·leetcode