AcWing 103. 电影(map、pair连用or离散化)

题目

方法一(map+pair)

 其实上面这么长巴拉巴拉就是在说

首先,每个科学家会的语言都不同。但是呢每部电影的字幕和语言是不一样的(字幕和语言一定不相同)

要求找到一部电影使得在场能听懂的科学家最多(如果存在两部及以上的电影的语言听懂人数相同的话,再去查找更多能看懂字幕的那部电影)

     思路分析

                1、使用map容器来存储科学家们听的懂的语言。
                2、使用pair(或者结构体)来存储科学家们能听得懂的语言和看的懂的字幕。
                3、然后先查找哪部电影最多科学家能听懂。
                4、接着再判断是否需要再查找哪部电影最多科学家能够看懂。

      ACcode

#include<iostream>
#include<cstring>
#include<algorithm>
#include<utility>
#include<map>
using namespace std;

const int maxn = 200010;

#define c_a first	//记录第i部电影的语音采用的编号
#define c_b second	 //记录第i部电影的字幕采用的编号
#define pii pair<int, int>	//存储某部电影所采用的语音编号和字幕编号

map<int, int>c;	  //记录科学家听得懂的某种语言出现的次数
pii p[maxn];

int a[maxn];	//记录第i个科学家懂得的语言

int main() {
	int n, m;
	std::ios::sync_with_stdio(false);	//消除输入输出缓存
	std::cin.tie(0);	//解除cin与cout的绑定,加快速率。
	cin >> n;
	for (int i = 0; i < n; i++) {
		cin >> a[i];
		c[a[i]]++;
	}

	cin >> m;
	for (int i = 0; i < m; i++) {
		cin >> p[i].c_a;
	}
	for (int i = 0; i < m; i++) {
		cin >> p[i].c_b;
	}

	//优先选择听懂电影语音的
	int max_a = 0, idx = 0;
	//max_a表示听得懂的语言最多的数目
	//idx用于记录电影编号
	for (int i = 0; i < m; i++) {
		if (max_a < c[p[i].c_a]) {
			max_a = c[p[i].c_a];
			idx = i;
		}
	}
	int max_b = 0;
	//max_b表示看得懂字幕最多的数目
	for (int i = 0; i < m; i++) {
		if (max_a == c[p[i].c_a]) {
			if (max_b < c[p[i].c_b]) {
				max_b = c[p[i].c_b];
				idx = i;
			}
		}
	}

	cout << idx + 1;	//因为上述程序是由0开始遍历,故加1
	return 0;
}

方法二 (离散化)

 来源于AcWing大佬的想法    大佬解题思路加源代码

     思路分析

                1、将不通序列中的所有可能都映射到一个数组中。
                2、然后利用该数组进行排序和去重。
                3、再然后再利用一些二分查找去计数就欧了。

     ACcode

#include<iostream>
#include<algorithm>
using namespace std;

const int maxn = 200010;
int lang[3 * maxn], uni[3 * maxn];
int a[maxn], b[maxn], c[maxn];
int ans[3 * maxn];

int idx = 0, tot = 0;

//find作用是把稀疏编号转为稠密编号
int find(int x) {
	return lower_bound(uni + 1, uni + 1 + idx, x) - uni;
}
int main() {
	int n, m;

	cin >> n;
	for (int i = 1; i <= n; i++) {	//科学家会的语言
		cin >> a[i];
		lang[++tot] = a[i];
	}
	cin >> m;
	for (int i = 1; i <= m; i++) {	//电影音频的语言
		cin >> b[i];
		lang[++tot] = b[i];
	}
	for (int i = 1; i <= m; i++) {	//电影字幕的语言
		cin >> c[i];
		lang[++tot] = c[i];
	}

	//排序lang,为了后续中的去重复操作
	sort(lang + 1, lang + 1 + tot);

	//把lang数组去重复,保存到uni数组
	for (int i = 1; i <= tot; i++) {
		if (i == 1 || lang[i] != lang[i - 1]) {
			uni[++idx] = lang[i];
		}
	}

	//用find转变成稠密编号,并用ans数组记录每种语言出现的次数。
	for (int i = 1; i <= n; i++) ans[find(a[i])]++;

	//遍历所有电影,按要求找到最多科学家会的电影
	int ans0, ans1, ans2;
	//ans0保存最终结果,ans1和ans2为中间结果
	ans0 = ans1 = ans2 = 0;
	for (int i = 1; i <= m; i++) {
		//算出第i个电影音频语言的科学家数,和第i个字幕语言的科学家数
		int anx = ans[find(b[i])], any = ans[find(c[i])];
		//如果ans大于ans1或者前者相等且any大于ans2时,更新
		if (anx > ans1 || (anx == ans1 && any > ans2)) {
			ans0 = i, ans1 = anx, ans2 = any;
		}
	}
	//如果所有的电影的声音和字幕的语言,科学家们都不懂,随便选一个
	if (ans0 == 0) {
		printf("%d\n", 1);
	}
	else {
		printf("%d\n", ans0);
	}
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/318474.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

neo4j 图数据库 py2neo 操作 示例代码

文章目录 摘要前置NodeMatcher & RelationshipMatcher创建节点查询获取节点节点有则查询&#xff0c;无则创建创建关系查询关系关系有则查询&#xff0c;无则创建 Cypher语句创建节点 摘要 利用py2neo包&#xff0c;实现把excel表里面的数据&#xff0c;插入到neo4j 图数据…

5288 SDH/PDH数字传输分析仪

5288 SDH/PDH数字传输分析仪 数字通信测量仪器 5288 SDH/PDH数字传输分析仪为高性能手持式数字传输分析仪&#xff0c;符合ITU-T SDH/PDH技术规范和我国光同步传输网技术体制的规定,支持2.048、34.368、139.264Mb/s及155.520Mb/s传输速率的测试。可进行SDH/PDH传输设备和网络的…

软件测试|如何使用Python显示指定年份日历

前言 如何在Python中打印日历&#xff1f;Python中提供了一个内置模块Calendar来打印展示日历&#xff0c;并且还提供了许多基于日历的操作&#xff0c;本文将向大家介绍如何使用Python来打印显示日历&#xff0c;并且对日历进行相应操作。 如何在Python中使用calendar Cale…

Java--RSA非对称加密的实现(使用java.security.KeyPair)

文章目录 前言实现步骤测试结果 前言 非对称加密是指使用不同的两个密钥进行加密和解密的一种加密算法&#xff0c;调用方用使用服务方提供的公钥进行加密&#xff0c;服务方使用自己的私钥进行解密。RSA算法是目前使用最广泛的公钥密码算法。Java提供了KeyPairGenerator类要生…

Open3D 反算点云缩放系数(21)

Open3D 反算点云缩放系数(21) 一、算法介绍二、算法实现1.方法12.方法2(通用)一、算法介绍 上一章按照指定的系数,对点云进行了等比例缩放,这里输入缩放后的两块点云,反算二者之间的缩放系数。 二、算法实现 已知使用的俩点云是1/2的缩放关系,用于验证计算结果是否…

SpringMVC(六)RESTful

1.RESTful简介 REST:Representational State Transfer,表现层资源状态转移 (1)资源 资源是一种看待服务器的方式,即,将服务器看作是由很多离散的资源组成。每个资源是服务器上一个可命名的抽象概念。因为资源是一个抽象的概念,所以它不仅仅能代表服务器文件系统中的一个文件…

解决Unexpected record signature 0X9maven 资源过滤

解决Unexpected record signature: 0X9|maven 资源过滤 记录问题&#xff1a;我们有个需求是根据excel模版导出一个excel表。我们的项目是SpringBoot&#xff0c;所以理所当然的把这个模版文件放到了&#xff0c;resources文件夹中。但是在导出文件的时候却遇到了invalid code …

黑马本地生活(列表页面,详情页面)

&#x1f3e1;浩泽学编程&#xff1a;个人主页 &#x1f525; 推荐专栏&#xff1a;《深入浅出SpringBoot》《java项目分享》 《RabbitMQ》《Spring》《SpringMVC》 &#x1f6f8;学无止境&#xff0c;不骄不躁&#xff0c;知行合一 文章目录 前言一、列表页面功…

iPhone“查找”最多可添加32个物品!

对于那些丢三落四的果粉来说&#xff0c;苹果的“查找”功能是一大福音。不管是丢失了iPhone、iPad、Mac、AirPods还是AirTag&#xff0c;都可以通过“查找”功能在地图上追踪设备的位置&#xff0c;甚至是远程锁定或抹掉设备的数据。 那么&#xff0c;iPhone的查找一次能支持添…

关于 ant-design-vue resetFields 失效

关于 ant-design-vue resetFields 失效 背景&#xff1a; 遇到这样的问题使用ant-design-vue useForm来制作表单的时候&#xff0c;resetFields()失效 场景&#xff1a; 编辑 -赋值 新增-初始值&#xff08;问题点&#xff1a;新增的时候他就不初始化&#xff09; 方案&…

机器人技能学习-构建自己的数据集并进行训练

概要 若想训练自己的场景&#xff0c;数据集的重要性不做过多赘述&#xff0c;下面就基于 robomimic 和 robosuite 构建自己的数据集进行讲解&#xff0c;同时&#xff0c;也会附上 train 和 run 的流程&#xff0c;这样&#xff0c;就形成了闭环。 自建数据集 采集数据 采…

RabbitMQ学习笔记

介绍 名词解释 Broker&#xff1a;接受和分发消息的应用&#xff0c;例如RabbitMQ Server Virtual host:出于多租户和安全因素设计的&#xff0c;把AMQP的基本组件划分到一个虚拟的分组中&#xff0c;类似于网络中的namespace概念。当多个不同的用户使用同一个RabbitMQ serv…

【SSM框架】SpringMVC

SpringMVC简介 SpringMVC概述 SpringMvC是一种基于Java实现MVC模型的轻量级web框架 SpringMVC技术与Servlet技术功能等同&#xff0c;用于表现层功能开发 SpringMVC入门 1、导入坐标 <dependency><groupId>javax.servlet</groupId><artifactId>ja…

98. 验证二叉搜索树(LeetCode)

文章目录 前言一、题目分析二、算法原理三、代码实现剪枝总结 前言 在本文章中&#xff0c;我们将要详细介绍一下Leetcode中第98题验证二叉搜索树&#xff0c; 在本内容中我们将会学到递归解决二叉树&#xff0c;全局变量&#xff0c;剪枝等等相关内容。 一、题目分析 分析&a…

【LabVIEW FPGA入门】使用数字IO卡实现计数器输入功能

方法1&#xff1a; 1.首先需要用一个数字IO的输入FPGA端口&#xff0c;并将其拖入程序框图中&#xff0c;同时创建一个循环。 2.如果想要在循环中实现累加功能&#xff0c;就可以使用移位寄存器。 数字输入的当前值和历史值进行比较&#xff0c;用于一个判断大于&#xff0c;来…

强化学习应用(二):基于Q-learning的物流配送路径规划研究(提供Python代码)

一、Q-learning算法简介 Q-learning是一种强化学习算法&#xff0c;用于解决基于马尔可夫决策过程&#xff08;MDP&#xff09;的问题。它通过学习一个值函数来指导智能体在环境中做出决策&#xff0c;以最大化累积奖励。 Q-learning算法的核心思想是使用一个Q值函数来估计每…

【论文阅读笔记】MobileSal: Extremely Efficient RGB-D Salient Object Detection

1.介绍 MobileSal: Extremely Efficient RGB-D Salient Object Detection MobileSal&#xff1a;极其高效的RGB-D显著对象检测 2021年发表在 IEEE Transactions on Pattern Analysis and Machine Intelligence。 Paper Code 2.摘要 神经网络的高计算成本阻碍了RGB-D显着对象…

SEU编译原理复习(期末考试用)——知识点+习题练习

这里给大家推荐下另一位博主的文章&#xff0c;我第一遍是看着这篇文章课本老师的复习PPT一起过的&#xff0c;二遍是做的作业题和老师发的往年卷&#xff1a;编译原理 乱七八糟的期末复习笔记_东南大学编译原理期末复习-CSDN博客 一、语言和文法&#xff08;10分&#xff09;…

CentOS7本地部署分布式开源监控系统Zabbix并结合内网穿透实现远程访问

前言 Zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。能监视各种网络参数&#xff0c;保证服务器系统的安全运营&#xff1b;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。 本地zabbix web管理界面限制在只能局域…

专业120+总分420+中山大学884信号与系统考研经验信息与通信工程电子信息

今年考研专业课120&#xff0c;总分420&#xff0c;顺利上岸。本人本科211末流&#xff0c;本科期间比较散漫&#xff0c;没有拿到本校保研资格&#xff0c;作为北方孩子&#xff0c;一直想到东南沿海地区&#xff0c;考研再三选择中山大学信通&#xff0c;该收心时候还是得逼一…