結果
問題 | No.1298 OR XOR |
ユーザー |
![]() |
提出日時 | 2020-12-23 17:35:30 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 4,650 bytes |
コンパイル時間 | 1,692 ms |
コンパイル使用メモリ | 176,468 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-09-21 16:27:18 |
合計ジャッジ時間 | 2,484 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 13 |
ソースコード
#include <bits/stdc++.h>#pragma GCC target("avx2")#pragma GCC optimize("O3")#pragma GCC optimize("unroll-loops")using namespace std;//--------------------------------------------------------------------#define all(a) (a).begin(),(a).end()#define rall(a) (a).rbegin(),(a).rend()#define overload4(_1,_2,_3,_4,name,...) name#define rep1(n) for(ll _=0;_<(ll)n;++_)#define rep2(i,n) for(ll i=0;i<(ll)n;++i)#define rep3(i,a,b) for(ll i=(ll)a;i<(ll)b;++i)#define rep4(i,a,b,c) for(ll i=(ll)a;i<(ll)b;i+=(ll)c)#define rep(...) overload4(__VA_ARGS__,rep4,rep3,rep2,rep1)(__VA_ARGS__)#ifdef _DEBUG#define pass(...) __VA_ARGS__ ;#define debug1(a) cerr<<#a<<": "<<a<<"\n"#define debug2(a,b) cerr<<#a<<": "<<a<<", "<<#b<<": "<<b<<"\n"#define debug3(a,b,c) cerr<<#a<<": "<<a<<", "<<#b<<": "<<b<<", "<<#c<<": "<<c<<"\n"#define debug4(a,b,c,d) cerr<<#a<<": "<<a<<", "<<#b<<": "<<b<<", "<<#c<<": "<<c<<", "<<#d<<": "<<d<<"\n"#define debug(...) overload4(__VA_ARGS__,debug4,debug3,debug2,debug1)(__VA_ARGS__)#else#define debug(...) void(0)#define pass(...) void(0);#endif#define mp make_pair//#define fi first//#define se secondvoid myset(){ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);}void doset(int n){cout << fixed << setprecision(n);cerr << fixed << setprecision(n);}#define koko cerr << "koko\n";using ll = long long;using ld = long double;using dou = double;template<class First,class Second>ostream& operator<<(ostream& os,const pair<First,Second>& pp){return os << "{" << pp.first << "," << pp.second << "}";}template<class T>ostream& operator<<(ostream& os,const vector<T>& VV){if(VV.empty())return os<<"[]";os<<"[";rep(i,VV.size())os<<VV[i]<<(i==VV.size()-1?"]":",");return os;}template<class T>ostream& operator<<(ostream& os,const set<T>& SS){if(SS.empty())return os<<"[]";os<<"[";auto ii=SS.begin();for(;ii!=SS.end();ii++)os<<*ii<<(ii==prev(SS.end())?"]":",");return os;}template<class Key,class Tp>ostream& operator<<(ostream& os,const map<Key,Tp>& MM){if(MM.empty())return os<<"[]";os<<"[";auto ii=MM.begin();for(;ii!=MM.end();ii++)os<<"{"<<ii->first<<":"<<ii->second<<"}"<<(ii==prev(MM.end())?"]":",");return os;}const int inf = 1 << 30;const ll INF = 1LL << 61;const ld pi = 3.14159265358;const ll mod1 = 1000000007LL;const ll mod2 = 998244353LL;typedef pair<ll,ll> P;template<class T, class U> inline bool chmin(T& a, const U& b){ if(a > b){ a = b; return 1; } return 0; }template<class T, class U> inline bool chmax(T& a, const U& b){ if(a < b){ a = b; return 1; } return 0; }ll modpow(ll n,ll m,ll MOD){if(m == 0)return 1;if(m < 0)return 0;ll res = 1;n %= MOD;while(m){if(m & 1)res = (res * n) % MOD;m >>= 1;n *= n;n %= MOD;}return res;}ll mypow(ll n,ll m){if(m == 0)return 1;if(m < 0)return -1;ll res = 1;while(m){if(m & 1)res = (res * n);m >>= 1;n *= n;}return res;}template<class T>inline bool isp(T n){bool res = true;if(n == 1 || n == 0)return false;else{for(ll i = 2;i * i <= n;i++){if(n % i == 0){res = false;break;}}return res;}}inline bool Yes(bool b = 1){cout << (b ? "Yes\n":"No\n");return b;}inline bool YES(bool b = 1){cout << (b ? "YES\n":"NO\n");return b;}map<ll,ll> primefactor(ll n){map<ll,ll> ma;if(n <= 1)return ma;ll m = n;for(ll i = 2;i * i <= n;i++){while(m % i == 0){ma[i]++;m /= i;}}if(m != 1)ma[m]++;return ma;}ll __lcm(ll a,ll b){return a / __gcd(a,b) * b;}template<class T>T sum(const vector<T> &V){T r=0;for(auto x:V)r+=x;return r;}template<class T>T sum(const initializer_list<T> &V){T r=0;for(auto x:V)r+=x;return r;}template<class T>T min(const vector<T> &V){return *min_element(all(V));}template<class T>T max(const vector<T> &V){return *max_element(all(V));}//--------------------------------------------------------------------int main(){myset();int N;cin >> N;int A = 0,B = 0,C = 0;int bit = 0;rep(i,31)bit += N >> i & 1;if(bit == 1){cout << "-1 -1 -1\n";return 0;}rep(i,31){if(N >> i & 1){if(A == 0){A = mypow(2,i);B = A;}else if(C == 0){C = mypow(2,i);A += C;}else{A += mypow(2,i);B += mypow(2,i);}}}cout << A << " " << B << " " << C << "\n";}