結果
問題 |
No.1988 Divisor Tiling
|
ユーザー |
![]() |
提出日時 | 2022-03-27 21:39:54 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 12 ms / 2,000 ms |
コード長 | 865 bytes |
コンパイル時間 | 1,881 ms |
コンパイル使用メモリ | 171,380 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-06 14:26:55 |
合計ジャッジ時間 | 3,537 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 32 |
ソースコード
#include <bits/stdc++.h> using namespace std; #define ll long long #define rep(i,n) for(int i=0;i<n;i++) #define riano_ std::ios::sync_with_stdio(false);std::cin.tie(nullptr) int main(){ riano_; ll N,H,W; cin >> N >> H; bool p2 = false; rep(i,10){ if(H==(1<<i)) p2 = true; } if(!p2) H = N/H; W = N/H; int ans[H][W]; vector<int> divs; rep(i,N-1){ if(N%(i+1)==0){ rep(j,i+1) divs.push_back(i+1); } } rep(i,H){ rep(j,W){ ans[i][j] = divs[i*W+j]; } } if(p2){ rep(i,H){ rep(j,W){ cout << ans[i][j] << " "; } cout << endl; } } else{ rep(i,W){ rep(j,H){ cout << ans[j][i] << " "; } cout << endl; } } }