当前位置: 首页 > news >正文

洛谷 P1102 A-B 数对 (Java)

洛谷 P1102 A-B 数对 (Java)

传送门:P1102 A-B 数对

题目: A-B 数对

题目背景

出题是一件痛苦的事情!

相同的题目看多了也会有审美疲劳,于是我舍弃了大家所熟悉的 A+B Problem,改用 A-B 了哈哈!

题目描述

给出一串正整数数列以及一个正整数 C C C,要求计算出所有满足 A − B = C A - B = C AB=C 的数对的个数(不同位置的数字一样的数对算不同的数对)。

输入格式

输入共两行。

第一行,两个正整数 N , C N,C N,C

第二行, N N N 个正整数,作为要求处理的那串数。

输出格式

一行,表示该串正整数中包含的满足 A − B = C A - B = C AB=C 的数对的个数。

样例 #1

样例输入 #1

4 1
1 1 2 3

样例输出 #1

3

提示

对于 75 % 75\% 75% 的数据, 1 ≤ N ≤ 2000 1 \leq N \leq 2000 1N2000

对于 100 % 100\% 100% 的数据, 1 ≤ N ≤ 2 × 1 0 5 1 \leq N \leq 2 \times 10^5 1N2×105 0 ≤ a i < 2 30 0 \leq a_i <2^{30} 0ai<230 1 ≤ C < 2 30 1 \leq C < 2^{30} 1C<230

2017/4/29 新添数据两组

分析:

创建一个 HashMap map,用于记录数组中每个数字的出现次数。

创建一个数组 a,用于存储输入的整数数组。

定义cnt 用于记录满足条件的数对个数。

再次循环数组 a,对于每个元素 a[i]:

如果 HashMap 中存在键值为 a[i]+c 的项,则将其值加到 cnt 中。
输出 cnt,即为满足条件的数对个数。

这个算法的时间复杂度为 O(N),其中 N 为数组长度。因为在第一个循环中构建了 HashMap,而在第二个循环中通过查找 HashMap 进行计数,每个查找操作的时间复杂度是 O(1)。因此总体的时间复杂度取决于循环次数,即 O(N)。

代码:

import java.util.*;public class Main{public static void main(String[] args) {     Scanner sc = new Scanner(System.in);int n = sc.nextInt();int c = sc.nextInt();Map<Integer,Integer> map = new HashMap<>();int [] a = new int [n];for(int i = 0;i < n;i++) {int tt = sc.nextInt();a[i] = tt;map.compute(tt, (key, value) -> (value == null) ? 1 : value + 1);}long cnt = 0;for(int i = 0;i < n;i++) {if(map.containsKey(a[i]+c)) {cnt += map.get(a[i]+c);}}System.out.println(cnt);sc.close();}
}
http://www.lryc.cn/news/299173.html

相关文章:

  • 情人节到了,写一份爱心程序(python)
  • Java图形化界面编程—— 基本组件和对话框 笔记
  • 使用Docker,拉取Nginx镜像,创建并运行Nginx容器
  • InstantBox:开箱即用的临时 Linux 环境
  • 【面试】国家公务员考试复试,面试内容准备方向(非技术面试考察点)
  • 点餐|外卖订餐小程序|基于微信小程序的外卖订餐系统设计与实现(源码+数据库+文档)
  • 使用Cargo创建、编译与运行Rust项目
  • Js中toFixed(2)精度问题的原因及解决办法
  • 【医学大模型 知识增强】SMedBERT:结构化语义知识 + 医学大模型 = 显著提升大模型医学文本挖掘性能
  • Python爬虫:安全与会话管理
  • [Python进阶] 识别验证码
  • 华为问界M9:全方位自动驾驶技术解决方案
  • Java 与 JavaScript 的区别与联系
  • React18原理: 时间分片技术选择
  • 【QT+QGIS跨平台编译】之三十三:【SpatiaLite+Qt跨平台编译】(一套代码、一套框架,跨平台编译)
  • 【JavaEE】_CSS选择器
  • Flaurm实现中文搜索
  • STM32自学☞定时器外部时钟案例
  • PyCharm中无法调用ffmpeg命令行
  • Go基础知识学习-习题题解
  • MyBatis中的XML实现和动态SQL实现
  • clickhouse计算前后两点间经纬度距离
  • 【51单片机】DS18B20(江科大)
  • Windows平台git clone文件路径太长报错
  • 中科大计网学习记录笔记(十):P2P 应用
  • Python算法题集_LRU 缓存
  • 局部加权回归
  • 国内国外最好的数据恢复软件评测,哪种数据恢复软件最有效?
  • bugku 1
  • C++ bfs再探迷宫游戏(五十五)【第二篇】