【每日一题】YACS P817:两数归零

题目描述

这是上海计算机学会竞赛P817:两数归零
标签 m a p map map、二分查找
给定 n n n 个整数 a 1 , a 2 , a 3 , . . . , a n a_1,a_2,a_3,...,a_n a1,a2,a3,...,an,请统计有多少二元组 i , j i,j i,j 满足 i < j i<j i<j 且满足 a i + a j = 0 a_i+a_j=0 ai+aj=0
数据范围: 1 < = n < = 300000 1<=n<= 300000 1<=n<=300000 − 1 , 000 , 000 , 000 ≤ a i ≤ 1 , 000 , 000 , 000 −1,000,000,000≤a_i≤1,000,000,000 1,000,000,000ai1,000,000,000

暴力枚举解法

很多同学看到题目就想着直接两层循环模拟,这样的时间复杂度是 O ( n 2 ) O(n^2) O(n2) 即最坏情况: 9 ∗ 1 0 10 9*10^{10} 91010,很明显会超时,这种方式能拿 60 60 60 分。
60 60 60 分代码

#include <bits/stdc++.h>
using namespace std;int a[300005];int main() {int n, ans = 0;cin >> n;for (int i = 1; i <= n; i++) cin >> a[i];for (int i = 1; i <= n; i++) {for (int j = i + 1; j <= n; j++) {if (a[i] + a[j] == 0) ans++;}}cout << ans << endl;return 0;
}

二分查找解法

我们课上讲过,可以通过二分去找到某个数字在有序序列中第一次出现的下标位置最后一次出现的下标位置,那么这个区间长度就是这个数字在这个序列中出现的次数。

当然手写二分,这也太累了吧。所以我们决定调用 S T L STL STL 中的二分查找函数。

l o w e r _ b o u n d ( a , a + n , v a l ) lower\_bound(a,a+n,val) lower_bound(a,a+n,val):找到有序序列 a a a 中大于等于 v a l val val 的第一个位置

u p p e r _ b o u n d ( a , a + n , v a l ) upper\_bound(a,a+n,val) upper_bound(a,a+n,val):找到有序序列 a a a 中大于 v a l val val 的第一个位置

通过位置差值获取 v a l val val在这个有序序列中的个数,那么回到这道题,我们可以先给 a a a数组排序,然后遍历每一个数 a i a_i ai,然后通过以上讲解的方式去得到这个有序序列中 − a i -a_i ai的个数,然后把个数进行一个累计。

当然,因为题目中要求 i < j i<j i<j,我们直接这样找会有重复的情况出现,比如第 1 1 1项和第 3 3 3项之和为 0 0 0,我们遍历到第 3 3 3项的时候又会把第 1 1 1项之和为 0 0 0的情况算上去,所以最终累计的计数要除以 2 2 2

代码

#include <bits/stdc++.h>
using namespace std;int a[300005];int main() {int n, ans = 0;cin >> n;for (int i = 1; i <= n; i++) cin >> a[i];sort(a + 1, a + 1 + n);for (int i = 1; i <= n; i++) {int l = lower_bound(a + 1, a + 1 + n, -a[i]) - a;int r = upper_bound(a + 1, a + 1 + n, -a[i]) - a;ans += r - l;}cout << ans / 2 << endl;return 0;
}

m a p 解法 map解法 map解法

直接从前往后遍历一遍,到第 i i i个数 a i a_i ai的时候,看看前面 − a i -a_i ai的个数,把计数加上去,最后就是答案了。该题 a i a_i ai数据范围比较大,并且有负数,所以我们需要用 m a p map map维护一下。
代码

#include <bits/stdc++.h>
using namespace std;int a[300005];
map<int, int> m;int main() {int n, ans = 0;cin >> n;for (int i = 1; i <= n; i++) {cin >> a[i];ans += m[-a[i]];m[a[i]]++;}cout << ans << endl;return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

面试官:你可以说一说你对Jmeter元素的理解吗?下

面试官&#xff1a;你可以说一说你对Jmeter元素的理解吗&#xff1f;下 监听器配置元素CSV数据集配置HTTPCookie管理器HTTP请求默认值登录配置元素 监听器 Listeners&#xff1a;显示测试执行的结果。它们可以以不同的格式显示结果&#xff0c;例如树、表、图形或日志文件 图…

嵌入式学习-驱动

嵌入式的一些基本概念 CPU与MCU的区别 CPU&#xff08;中央处理器&#xff0c;central processing unit) 指集成了运算器、控制器、寄存器、高速缓存等功能模块的芯片&#xff0c;负责执行计算机程序指令的处理器。MCU&#xff08;单片微型计算机或单片机&#xff0c;microco…

LLM大语言模型(五):用streamlit开发LLM应用

目录 背景准备工作切记streamlit开发LLM demo开一个新页面初始化session先渲染历史消息接收用户输入模拟调用LLM 参考 背景 Streamlit是一个开源Python库&#xff0c;可以轻松创建和共享用于机器学习和数据科学的漂亮的自定义web应用程序&#xff0c;用户可以在几分钟内构建一…

DNS欺骗

DNS(域名系统)作为当前全球最大 、最复杂的分布式层次数据库系统&#xff0c;具有着开放、庞大、复杂的特性。它为全球用户提供域名解析服务&#xff0c;是互联网的重要基础设施。但由于其在设计之初未考虑安全性、人为破坏等因素 &#xff0c;DNS系统在互联网高度发达的今天面…

项目中好用的安装包

react TScript 移动端 安装脚手架&#xff0c;文件名为 xm_csdn &#xff0c;配合使用 TS npx create-react-app xm_csdn --template typescript安装 sass yarn add sass安装路由及路由类型声明文件 // 路由 yarn add react-router-dom5.3.0 // 声明文件 yarn add types/…

Ubuntu下APT下载工具(Ubuntu 下最常用的下载和安装软件方法)

前言 本篇文章记录我学习Ubuntu 下用的最多的下载工具&#xff1a; APT 下载工具&#xff0c; APT 下载工具可以实现软件自动下载、配置、安装二进制或者源码的功能。 APT 下载工具和我们前面一篇文章讲解的“install”命令结合在一起构成了 Ubuntu 下最常用的下载和安装软件方…

【代码随想录】LC 242. 有效的字母异位词

文章目录 前言一、题目1、原题链接2、题目描述 二、解题报告1、思路分析2、时间复杂度3、代码详解 前言 本专栏文章为《代码随想录》书籍的刷题题解以及读书笔记&#xff0c;如有侵权&#xff0c;立即删除。 一、题目 1、原题链接 242. 有效的字母异位词 2、题目描述 二、解题…

机器学习面试题总结1-59

目录 1.请简要介绍下SVM。 2.请简要介绍下Tensorflow的计算图。 3.请问GBDT和XGBoost的区别是什么?

刘知远团队大模型技术与交叉应用L5-BMSystem

为什么需要BMTrain&#xff1f; PLM越来越大。为了使训练更高效和廉价。我们有必要 1.分析GPU的显存去哪了&#xff1f; 2.理解GPU间的合作模式是如何的&#xff1f; 显存都去了哪里&#xff1f; CPU vs GPU CPU适合复杂逻辑运算。GPU适合大量重复的数值运算。 显存成分 1.前…

csp----寻宝!大冒险!

题目描述&#xff1a; AC代码如下&#xff1a; /*思路&#xff1a; 把A变成小块 因为B是A里的一部分 通过把A变成小块 去寻找B这样速度更快 如果AB,BA&#xff0c;说明找到了。 */#include <iostream> #include <cstring> #include <algorithm> #include …

python3-cookbook-字典排序

第一章&#xff1a;数据结构和算法 Python 提供了大量的内置数据结构&#xff0c;包括列表&#xff0c;集合以及字典。大多数情况下使用这些数据结构是很简单的。但是&#xff0c;我们也会经常碰到到诸如查询&#xff0c;排序和过滤等等这些普遍存在的问题。 因此&#xff0c;这…

【Java】初识Spring Mvc

SpringMVC_day01 今日内容 理解SpringMVC相关概念完成SpringMVC的入门案例学会使用PostMan工具发送请求和数据掌握SpringMVC如何接收请求、数据和响应结果掌握RESTful风格及其使用完成基于RESTful的案例编写 1&#xff0c;SpringMVC简介 看到SpringMVC这个名字我们会发现其中…

【人工智能】主要人工智能技术及深度学习及传统机器学习区别与联系

主要人工智能技术的基本概念和应用场景 机器学习英文简称ML是一门涉及统计学、系统辨识、逼近理论、优化理论、计算机科学、脑科学等诸多领域的交叉学科&#xff0c;主要研究计算机怎样模拟或实现人类的学习行为&#xff0c;以获取新的知识或技能&#xff0c;重新组织已有的知识…

【GAMES101】Lecture 10 几何表示

目录 隐式表示 代数曲面&#xff08;Algebraic surfaces&#xff09; CSG&#xff08;Constructive solid geometry&#xff09; 距离函数&#xff08;Distance Functions&#xff09; 水平集&#xff08;Level set methods&#xff09; 分形&#xff08;Fractals&#x…

【Android】MediaCodec学习

在开源Android屏幕投屏代码scrcpy中&#xff0c;使用了MediaCodec去获取和display关联的surface的内容&#xff0c;再通过写fd的方式&#xff08;socket等&#xff09;传给PC端&#xff0c; MediaCodec的处理看起来比较清楚&#xff0c;数据in和数据out 这里我们做另外一个尝试…

计算机网络(第六版)复习提纲16

三 IP地址与MAC地址 1 IP层只能看到IP数据报 2 路由器只根据目的IP地址进行转发 3 局域网的链路层只能看到MAC帧 4 IP层抽象的互联网屏蔽了下层的复杂细节&#xff0c;在网络层讨论问题能够使用统一的、抽象的IP地址来研究主机和主机或路由间的通信 问题&#xff1a; 1 主机或路…

AI嵌入式K210项目(19)-安装CanMV IDE开发软件

文章目录 前言一、软件下载安装二、软件简介三、设备连接四、在线模拟五、开机运行程序附录&#xff1a;MicroPython固件烧录总结 前言 前几章我们介绍K210使用C语言裸机开发方法&#xff0c;大家对K210内部的硬件和各种加速器有了初步的了解&#xff0c;但是开发人工智能相关…

TypeScript(四) 运算符

1. 运算符 1.1. 描述 运算符用于执行程序代码运算。 1.2. 运算符主要包括&#xff1a; &#xff08;1&#xff09;算术运算符 &#xff08;2&#xff09;逻辑运算符 &#xff08;3&#xff09;关系运算符 &#xff08;4&#xff09;按位运算符 &#xff08;5&#xff09;赋值…

C++异步编程

thread std::thread 类代表一个单独的执行线程。在创建与线程对象相关联时&#xff0c;线程会立即开始执行&#xff08;在等待操作系统调度的延迟之后&#xff09;&#xff0c;从构造函数参数中提供的顶层函数开始执行。顶层函数的返回值被忽略&#xff0c;如果它通过抛出异常…

内部类 --java学习笔记

内部类 是类中的五大成分之一&#xff08;成员变量、方法、构造器、内部类、代码块&#xff09;&#xff0c;如果一个类定义在另一个类的内部&#xff0c;那么这个类就是内部类当一个类的内部包含了一个整体的事务&#xff0c;且这个事务没必要单独设计时&#xff0c;就可以把…