結果

問題 No.2929 Miracle Branch
ユーザー cled0328
提出日時 2024-10-12 17:00:38
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
WA  
実行時間 -
コード長 807 bytes
コンパイル時間 3,506 ms
コンパイル使用メモリ 195,416 KB
最終ジャッジ日時 2025-02-24 18:48:10
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2 WA * 1
other AC * 5 WA * 38
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

int main(){
    long long x;cin>>x;
    if(x==1){
        cout<<"2\n1 2\nb g\n";
        return 0;
    }
    vector<int> vc;
    for(int i=3;i<2e5;i++){
        if(x==1||x==2)break;
        while(x%i==0){
            vc.push_back(i);
            x/=i;
        }
    }
    if(x==2)vc.push_back(2);
    if(x>2){
        cout<<"-1\n";
        return 0;
    }
    int sm=0;
    for(auto i:vc)sm+=i+1;
    if(sm>2e15){
        cout<<"-1\n";
        return 0;
    }
    int n=vc.size();
    cout<<sm<<"\n";
    for(int i=1;i<n;i++)cout<<i<<" "<<i+1<<"\n";
    int cnt=n+1;
    for(int i=0;i<n;i++){
        for(int j=0;j<vc[i];j++){
            cout<<i+1<<" "<<cnt<<"\n";
        }
        cnt++;
    }
    for(int i=0;i<sm;i++)cout<<(i<n?"b":"g")<<" \n"[i+1==sm];
}
0