分数 20
全屏浏览题目
切换布局
作者 朱允刚
单位 吉林大学
对于一个整型数组(p1,p2,…,pn),如果某个下标小的元素是下标大的元素的倍数,我们称这两个元素为倍数对。形式化地,若存在i和j,满足i<j且pi是pj的倍数,则称(pi,pj)为倍数对。给定一个整型数组,数组元素是整数1…n的一个排列组合,请编写程序,计算该数组中所有倍数对的数目。
输入格式:
每个测试点包含多组数据。第一行是整数T(1≤T≤104),表示测试数据组数。对于每组数据,第一行为整数n(1≤n≤105),表示给定数组的长度,第二行为n个空格间隔的整数,表示给定的数组,保证给定的数组是整数1…n的一个排列组合。保证∑n≤106。
输出格式:
对每组数据输出一行,为一个整数,表示数组中倍数对的数目。
输入样例:
2
5
1 4 3 2 5
5
5 4 3 2 1
输出样例:
1
5
解释:
样例1:倍数对为(4,2)。
样例2:倍数对为(5,1), (4,1), (3,1), (2,1), (4,2)。
数据规模:
测试点0: n≤10;
测试点1-2: 10<n≤100;
测试点3: T>1000,105<∑n≤106。
#include<iostream>
using namespace std;
int main()
{
int N;
cin >> N;
while (N > 0)
{
N--;
int n, count = 0;
cin >> n;
int* visit = new int[n + 1];//申请a+1个新空间
int* a = new int[n + 1];
for (int i = 1; i <= n; i++)
{
cin >> a[i];
}
for (int i = n; i >= 1; i--)
{
count += visit[a[i]];
for (int k = a[i]; k <= n; k += a[i])//判断倍数,筛选
{
visit[k]++;
}
}
cout << count << endl;
}
}