結果

問題 No.3553 Good Quartet
コンテスト
ユーザー 沙耶花
提出日時 2026-05-22 23:47:45
言語 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
結果
WA  
実行時間 -
コード長 1,088 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 3,247 ms
コンパイル使用メモリ 280,364 KB
実行使用メモリ 16,640 KB
最終ジャッジ日時 2026-05-22 23:47:58
合計ジャッジ時間 9,188 ms
ジャッジサーバーID
(参考情報)
judge1_1 / judge3_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other WA * 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];
	map<int,int> mp;
	vector<int> t=  {1,5,7,11};
	
	rep(i,n){
		rep(j,4){
			if(s[i]%t[j]==0)mp[s[i]/t[j]]++;
		}
	}
	int ans = 0;
	for(auto a:mp){
		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]--;
				}
			}
		}
		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