結果
問題 | No.223 1マス指定の魔方陣 |
ユーザー |
![]() |
提出日時 | 2015-06-05 23:47:49 |
言語 | C++11 (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,170 bytes |
コンパイル時間 | 470 ms |
コンパイル使用メモリ | 69,488 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-07-06 14:24:21 |
合計ジャッジ時間 | 1,813 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | WA * 1 |
other | WA * 46 |
ソースコード
#include<iostream> #include<cstdio> #include<vector> #include<queue> #include<map> #include<string> #include<algorithm> #include<functional> using namespace std; #define FOR(i,a,b) for (int i=(a);i<(b);i++) #define RFOR(i,a,b) for (int i=(b)-1;i>=(a);i--) #define REP(i,n) for (int i=0;i<(n);i++) #define RREP(i,n) for (int i=(n)-1;i>=0;i--) #define INF 1<<30 #define MP make_pair #define mp make_pair #define pb push_back #define PB push_back #define DEBUG(x) cout<<#x<<": "<<x<<endl #define ll long long #define ull unsigned long long int main(){ int n,x,y,z; cin>>n>>x>>y>>z; int ma[n][n]; int b[n][n][n]; REP(i,n){ REP(j,n){ ma[i][j]=i*n+j; if((i%4)==(j%4) || 3-(i%4)==(j%4)){ ma[i][j]=n*n-1-ma[i][j]; } REP(k,n){ if((ma[i][j]>>k)&1) b[i][j][k]=1; else b[i][j][k]=0; } } } int bin=0; REP(i,n){ if ((ma[y][x]>>i)%2==1 && (z>>i)%2==1){ }if ((ma[y][x]>>i)%2==1 && (z>>i)%2==0){ bin |= (1<<i); }if ((ma[y][x]>>i)%2==0 && (z>>i)%2==1){ bin |= (1<<i); }if ((ma[y][x]>>i)%2==0 && (z>>i)%2==0){ } } REP(i,n)REP(j,n) ma[i][j]^=bin; REP(i,n){ REP(j,n){ cout<<ma[i][j]<<" "; } cout<<endl; } return 0; }