結果
問題 |
No.2929 Miracle Branch
|
ユーザー |
![]() |
提出日時 | 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 |
ソースコード
#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]; }