結果

問題 No.3553 Good Quartet
コンテスト
ユーザー 沙耶花
提出日時 2026-05-23 00:00:14
言語 C++17
(gcc 15.2.0 + boost 1.89.0)
コンパイル:
g++-15 -O2 -lm -std=c++17 -Wuninitialized -DONLINE_JUDGE -o a.out _filename_
実行:
./a.out
結果
AC  
実行時間 1,177 ms / 2,000 ms
コード長 1,759 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 3,453 ms
コンパイル使用メモリ 281,304 KB
実行使用メモリ 27,520 KB
最終ジャッジ日時 2026-05-23 00:00:35
合計ジャッジ時間 13,692 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge1_1
純コード判定待ち
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 15
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include <stdio.h>
#include <atcoder/all>
#include <bits/stdc++.h>
using namespace std;
using namespace atcoder;
using mint = modint998244353;
#define rep(i,n) for (int i = 0; i < (n); ++i)
#define Inf32 1000000001
#define Inf64 4000000000000000001LL


int main(){
	int n,q;
	cin>>n>>q;
	vector<int> s(n);
	rep(i,n)cin>>s[i];
	/*
	rep(i,100){
		rep(j,100){
			rep(k,100){
				int x = i+1,y = j+1,z = k+1,w = (j+k+2)-(i+1);
				if(x>=y||y>=z||z>=w)continue;
				int s = x+y+z+w;
				int t = 0;
				if(s%(x+y)==0)t++;
				if(s%(x+z)==0)t++;
				if(s%(x+w)==0)t++;
				if(s%(y+z)==0)t++;
				if(s%(y+w)==0)t++;
				if(s%(z+w)==0)t++;
				if(t!=4)continue;
				cout<<x<<' '<<y<<' '<<z<<' '<<w<<endl;
			}
		}
	}*/
	
	map<int,int> mp,mp2;
	vector<int> t=  {1,5,7,11};
	vector<int> t2=  {1,11,19,29};
	
	rep(i,n){
		rep(j,4){
			if(s[i]%t[j]==0)mp[s[i]/t[j]]++;
			if(s[i]%t2[j]==0)mp2[s[i]/t2[j]]++;
		}
	}
	int ans = 0;
	for(auto a:mp){
		if(a.second==4)ans++;
	}
	for(auto a:mp2){
		if(a.second==4)ans++;
	}
	rep(_,q){
		int x,y;
		cin>>x>>y;
		rep(j,4){
			if(y%t[j]==0){
				int z = y/t[j];
				if(x==1){
					mp[z]++;
					if(mp[z]==4)ans++;
				}
				else{
					if(mp[z]==4)ans--;
					mp[z]--;
				}
			}
			
			if(y%t2[j]==0){
				int z = y/t2[j];
				if(x==1){
					mp2[z]++;
					if(mp2[z]==4)ans++;
				}
				else{
					if(mp2[z]==4)ans--;
					mp2[z]--;
				}
			}
		}
		cout<<ans<<endl;
	}
	/*	
	rep(i,1<<n){
		if(__builtin_popcount(i)!=4)continue;
		vector<int> v;
		int sum = 0;
		rep(j,n){
			if((i>>j)&1){
				v.push_back(s[j]);
				sum += s[j];
			}
		}
		int t = 0;
		rep(j,4){
			rep(k,4){
				if(j<k && sum % ((v[j]+v[k]))==0){
					t++;
				}
			}
		}
		if(t==4){
			cout<<v[0]<<' '<<v[1]<<' '<<v[2]<<' '<<v[3]<<endl;
		}
	}
		*/
	return 0;
}
0