传送门

题目大意

两个整数Codeforces 1470 B_算法Codeforces 1470 B_算法_02是有关的当Codeforces 1470 B_5e_03
给你一个长度为Codeforces 1470 B_5e_04的序列Codeforces 1470 B_i++_05。每一秒,所有的Codeforces 1470 B_5e_06都会变成序列中所有和它有关的数的乘积。
Codeforces 1470 B_i++_07为数列中与Codeforces 1470 B_5e_06有关的数的个数。
Codeforces 1470 B_算法_09次询问,每次询问给出一盒Codeforces 1470 B_算法_10,求在Codeforces 1470 B_算法_10秒时的Codeforces 1470 B_i++_12

思路

代码

const int maxn = 3e5+7;
const ll mod = 1e9+7;
const ll INF=5e18+7;
const int inf=1e9+7;
const ll maxx=1e6+700;
 
int n;
int a[maxn];
int q;
ll w; 
struct node{
	int x;
	int cnt;
}str[maxn];
map<int,int>mp;
 
void init(int x){
	for(int i=2;i*i<=x;i++){
		if(x%i==0){
			int cnt1=0;
			while(x%i==0){
				cnt1++;
				x/=i;
			}
			if(cnt1%2) x*=i;
		}
	}
	mp[x]++;
}
 
int main(){
	int t;
	scanf("%d",&t);
	while(t--){
		mp.clear();
		scanf("%d",&n);
		for(int i=1;i<=n;i++){
			scanf("%d",&a[i]); 
			init(a[i]);
		}
		int ans1=0,ans2=0;
		map<int,int>::iterator it;
		for(it=mp.begin();it!=mp.end();it++){
			ans1=max(ans1,it->second); 
			if(it->second%2==0||it->first==1){
				ans2+=it->second;
			} 
		}
		ans2=max(ans1,ans2);
		scanf("%d",&q);
		while(q--){
			scanf("%lld",&w);
			if(w==0){
				printf("%d\n",ans1);
			}
			else{
				printf("%d\n",ans2);
			}
		}
	}
}