結果

問題 No.3126 Dual Query Problem
ユーザー ゼリトキ
提出日時 2025-04-25 21:43:56
言語 C++23
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 342 ms / 2,000 ms
コード長 821 bytes
コンパイル時間 3,868 ms
コンパイル使用メモリ 287,412 KB
実行使用メモリ 9,020 KB
最終ジャッジ日時 2025-06-20 02:43:00
合計ジャッジ時間 15,165 ms
ジャッジサーバーID
(参考情報)
judge4 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 33
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
#define rep(i, n) for (int i = 0; i < (int)(n); i++)
#define ll long long
#define mod 998244353
int main(){
    cin.tie(0)->sync_with_stdio(0);
    cout.tie(0);
    int N,Q;
    int X[200009];
    cin>>N>>Q;
    for(int i=1;i<=N;i++) cin>>X[i];
    vector<int>siz;
    for(int i=1;i<=N;i++) siz.push_back(X[i]);
    sort(siz.begin(),siz.end());
    siz.erase(unique(siz.begin(),siz.end()),siz.end());
    if(siz.size()+N>Q){
        cout<<"No"<<endl;
        return 0;
    }
    cout<<"Yes"<<endl;
    map<int,int>dat;
    for(int i=1;i<=siz.size();i++){
        cout<<"1 "<<i<<" "<<siz[i-1]<<endl;
        dat[siz[i-1]]=i;
    }
    for(int i=1;i<=N;i++){
        cout<<"2 "<<dat[X[i]]<<endl;
    }
    for(int i=siz.size()+N;i<Q;i++){
        cout<<"1 1 1"<<endl;
    }
}

0