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

【16届蓝桥杯寒假刷题营】第2期DAY4

【16届蓝桥杯寒假刷题营】第2期DAY4 - 蓝桥云课

问题描述

幼儿园小班的浩楠同学有一个序列 a。
他想知道有多少个整数三元组 (i,j,k) 满足 1≤i,j,k≤n 且 ai​×aj​=ak​。

输入格式

共2行,第一行一个整数 n,表示序列的长度。
第二行 n 个整数,表示序列的每一项。

输出格式

共一行,一个整数 ans,表示三元组的个数。

样例输入

5
2 3 4 5 6

样例输出

3

说明

满足条件的三元组有 (1,1,3), (1,2,5), (2,1,5)。

评测数据规模

对于100%的评测数据,1≤n≤1e5,1≤ai​≤1e5。

思路:

这题n最大1e5。我们可以优化成mlogm。

考虑枚举 ai​,aj​,可以发现当 ai​ 很大时,如果想要 ai​×aj​ 在 a 中出现,aj​ 必须很小。

下面证明这样枚举的时间复杂度时合理的:

根据调和级数 ∑i=1n​i1​=O(nlogn)。

设 m=105,那么满足 i×j≤m 的 (i,j) 至多只有 O(mlogm) 对。

记录每个元素出现的次数并统计即可。

时间复杂度 O(mlogm)。

代码如下:

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
typedef long long ll;
const ll N = 1e5+10;
const ll M = 1e5;
ll n; 
ll has[N];
ll sum;
int main(void)
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
	cin >> n;
	for(ll i = 1 ; i <= n ; i++)
	{
		ll x;
		cin >> x;
		has[x]++;
	}
	//暴力枚举
	for(ll i = 1 ; i <= M ; i++)
	{
		for(ll j = 1 ; i * j <= M ; j++)
		{
			sum += has[i]*has[j]*has[i*j];		
		}
	} 
	cout << sum;
}


http://www.kler.cn/a/525022.html

相关文章:

  • Hive:日志,hql运行方式,Array,行列转换
  • LangChain的开发流程
  • “AI视频智能分析系统:让每一帧视频都充满智慧
  • 机器学习(三)
  • 设计模式面试题
  • DataWhale组队学习 leetCode task4
  • 安卓逆向之脱壳-认识一下动态加载 双亲委派(二)
  • 洛谷P3383 【模板】线性筛素数
  • 在Visual Studio Code自带的按键编译无法使用该怎么办
  • JavaScript_01
  • Baklib如何重新定义企业知识管理提升组织效率与创新力
  • MyBatis 缓存机制详解
  • Java学习教程,从入门到精通,JDBC 删除表语法及案例(103)
  • 基于Langchain-Chatchat + ChatGLM 本地部署知识库
  • 240. 搜索二维矩阵||
  • 【JavaEE】Spring(6):Mybatis(下)
  • docker安装emqx
  • 11JavaWeb——SpringBootWeb案例02
  • S4 HANA明确Tax Base Amount是否考虑现金折扣(OB69)
  • 蓝桥杯python语言基础(4)——基础数据结构(下)
  • 洛谷P11464 支配剧场
  • 深度学习框架应用开发:基于 TensorFlow 的函数求导分析
  • SpringSecurity:There is no PasswordEncoder mapped for the id “null“
  • Kotlin 委托详解
  • 新项目传到git步骤
  • 【Redis】 String 类型的介绍和常用命令