P1102 A-B 数对 (非二分,不开龙永远的痛,用map解决)

可是我真的会伤心

题目链接

思路:1.本来想的是暴力,两层循环模拟每个数。

2.后来想先把每个数字的个数求出来放在数组nums【】中,并把不重复的数字存到数组b,再两层循环b数组应该时间复杂度会好些,如果b数组中的两个数满足条件,则把nums【i】*nums【b】加入到答案ans中。

暴力代码:76分

#include<algorithm>
#include<iostream>
#include<cstring>
#include<queue>
#include<cmath>using namespace std;int n,c;
long long a[1000010];
int cnt;int main()
{scanf("%d%d",&n,&c);for(int i=0;i<n;i++){scanf("%lld",&a[i]);}sort(a,a+n);//先思考暴力的//可以用窗口 for(int i=0;i<n-1;i++){for(int j=i+1;j<n;j++){if(a[j] - a[i] == c){cnt++;}}} printf("%d",cnt);return 0;
}

结果:

尝试代码:

#include<algorithm>
#include<iostream>
#include<cstring>
#include<queue>
#include<cmath>using namespace std;int n,c;
long long a[1000010];
long long b[1000010];int nums[1000010]; 
int cnt;
int t;int main()
{scanf("%d%d",&n,&c);for(int i=0;i<n;i++){scanf("%lld",&a[i]);}sort(a,a+n);nums[a[0]] = 1;b[0] = a[0];//找出每个数对应的个数,如果它减取前面一个数等于c就直接加上他的个数for(int i=1;i<n;i++){if(a[i] != a[i-1]){t++;nums[a[i]] ++;b[t] = a[i];}else nums[a[i]] ++;}
//	for(int i=0;i<=t;i++){
//		cout<<b[i]<<" ";
//	}
//	cout<<endl;//	for(int i=0;i<100;i++){
//		cout<<nums[i]<<" ";
//	}
//	cout<<endl;for(int i=0;i<t;i++){for(int j=i+1;j<=t;j++){if(b[j] - b[i] == c){cnt += nums[b[j]] * nums[b[i]];}}}printf("%d",cnt);return 0;} 

结果:

代码3:不开龙永远的痛

#include<algorithm>
#include<iostream>
#include<cstring>
#include<queue>
#include<cmath>using namespace std;long long n,c;
long long a[1000010];
long long b[1000010];long long nums[1000010]; 
long long cnt;
long long t;int main()
{scanf("%lld%lld",&n,&c);for(int i=0;i<n;i++){scanf("%lld",&a[i]);}sort(a,a+n);nums[a[0]] = 1;b[0] = a[0];//找出每个数对应的个数,如果它减取前面一个数等于c就直接加上他的个数for(int i=1;i<n;i++){if(a[i] != a[i-1]){t++;nums[a[i]] ++;b[t] = a[i];}else nums[a[i]] ++;}
//	for(int i=0;i<=t;i++){
//		cout<<b[i]<<" ";
//	}
//	cout<<endl;//	for(int i=0;i<100;i++){
//		cout<<nums[i]<<" ";
//	}
//	cout<<endl;for(int i=0;i<t;i++){for(int j=i+1;j<=t;j++){if(b[j] - b[i] == c){cnt += nums[b[j]] * nums[b[i]];}}}printf("%lld",cnt);return 0;} 

结果:92分

AC代码:用map

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<bits/stdc++.h>
using namespace std;
int n,c;
int a[200010];
long long ans;
map<int, int> m;//map是映射,map<A,B> 字母A对应个数B 
int main()
{scanf("%d%d",&n,&c);for(int i = 1; i <= n; i++){scanf("%d",&a[i]);m[a[i]] ++;}for(int i = 1; i <= n; i++){ans += m[a[i] + c];}printf("%lld",ans);return 0;
} 

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

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

相关文章

欧拉路径欧拉回路

欧拉回路&#xff0c;指遍历图时通过图中每条边且仅通过一次&#xff0c;最终回到起点的一条闭合回路&#xff0c;适用于有向图与无向图&#xff0c;如果不强制要求回到起点&#xff0c;则被称为欧拉路径。 欧拉图&#xff1a;具备欧拉回路的图 无向图&#xff1a;图的所有顶…

全球范围内2nm晶圆厂建设加速

随着人工智能浪潮席卷而来&#xff0c;先进制程芯片的重要性日益凸显。当前&#xff0c;3nm工艺节点是行业内最先进的节点。与此同时&#xff0c;台积电、三星、英特尔、Rapidus等厂商正积极布局建设2nm晶圆厂。台积电与三星此前计划于2025年量产2nm芯片&#xff0c;而Rapidus则…

【Java】Thread详解

&#x1f352;前言 本文将从以下几方面来展开对Thread的介绍。 1.线程创建 2.线程中断 3.线程等待 4.线程休眠 在前面的文章中&#xff0c;已经总结了关于Thread的一些理解。 在阅读本文之前&#xff0c;最好对其有一些基础的了解。 文章链接: 【JavaSE】进程是什么&#xff1f…

基于lora技术微调Gemma(2B)代码实践

一、前置条件 获得模型访问权&#xff0c;选择Colab运行时&#xff0c;配置训练环境。 先在Kaggle上注册&#xff0c;然后获得Gemma 2B 的访问权&#xff1b; 然后在Google colab 配置环境&#xff0c;主要是GPU的选择&#xff0c;免费的是T4&#xff0c;建议采用付费的A100…

C++——list类及其模拟实现

前言&#xff1a;这篇文章我们继续进行C容器类的分享——list&#xff0c;也就是数据结构中的链表&#xff0c;而且是带头双向循环链表。 一.基本框架 namespace Mylist {template<class T>//定义节点struct ListNode{ListNode<T>* _next;ListNode<T>* _pre…

【重学C语言】三、C语言最简单的程序

【重学C语言】三、C语言最简单的程序 最简单的程序头文件使用尖括号 < >使用双引号 ""区别与注意事项示例 主函数认识三个错误 常量和变量常量ASCII 码表转义字符 关键字数据类型关键字存储类关键字修饰符关键字控制流程关键字函数相关关键字其他关键字 变量变…

Linux 恶意软件“Migo”针对 Redis 进行加密劫持攻击

安全研究人员遇到了一种新的加密劫持活动&#xff0c;该活动使用一种名为 Migo 的新恶意软件&#xff0c;该恶意软件针对 Linux 主机上的 Redis 服务器。在 Cado Security 研究人员注意到在野外利用 Redis 系统的新命令后&#xff0c;该活动曝光了。 初始访问 根据 Cado secu…

RUST语言基本数据类型认识

1.RUST的基本数据类型参考: 2.使用RUST数据类型声明变量并赋值: let a:i8=1;//8位有符号整数let a1:u8=2;//8位无符号整数let b:i16=1;//16位有符号整数let b1:u16=2;//16位无符号整数let c:i32=1;//32位有符号整数let c1:u32=2;//32位无符号整数let d:i64=1;//64位有符号整数l…

公众号爆文策略与实践:揭秘千万阅读量的秘密

1. 引言 介绍公众号爆文的重要性&#xff0c;以及分享个人通过每天投入半小时赚到30倍门票的经验。强调跟上大佬步伐&#xff0c;提升认知的重要性。 2. 爆文的底层逻辑 2.1 推荐的底层逻辑 内容分发机制的变化&#xff0c;从仅限于直接关注到通过搜索、浏览推荐等多种方式…

【项目实战经验】DataKit迁移MySQL到openGauss(上)

前言 本文将分享DataKit迁移MySQL到openGauss的项目实战&#xff0c;供广大openGauss爱好者参考。 1. 下载操作系统 https://www.openeuler.org/zh/download https://support.huawei.com/enterprise/zh/doc/EDOC1100332931/1a643956 https://support.huawei.com/enterprise…

封装一个vue3的公共组件

在Vue 3中&#xff0c;封装公共组件的场景包括但不限于以下几种情况&#xff1a; 重复使用的组件&#xff1a;如果你发现某个组件在多个地方重复使用&#xff0c;那么将其封装成公共组件是很有意义的。比如&#xff0c;页面中的各种表单控件&#xff08;输入框、下拉框、日期选…

硬件开发文档规范

本文出发点&#xff1a; 一般来说&#xff0c;越是大公司越注重开发文档的规范性&#xff0c;因为这样最大的好处是能够保证开发的连贯性&#xff0c;也就是即使有员工离职了&#xff0c;只要开发文档是齐全的&#xff0c;新员工入职后&#xff0c;就能够很快接手工作&#xf…