結果
問題 | No.630 門松グラフ |
ユーザー |
|
提出日時 | 2020-08-18 19:35:23 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 28 ms / 1,500 ms |
コード長 | 918 bytes |
コンパイル時間 | 676 ms |
コンパイル使用メモリ | 69,856 KB |
最終ジャッジ日時 | 2025-01-13 03:23:37 |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 32 |
ソースコード
#include <iostream> #include <vector> using lint = long long; void solve() { int n, m; std::cin >> n >> m; int n1 = n / 2, n2 = n - n1; if (m < n - 1 || lint(n1) * n2 < m) { std::cout << "NO\n"; return; } std::cout << "YES\n"; for (int i = 1; i <= n; ++i) std::cout << i << " "; std::cout << "\n"; for (int u = 1; u <= n1; ++u) { for (int d = 0; d <= 1; ++d) { int v = u + d; if (n2 < v) continue; std::cout << u << " " << v + n1 << "\n"; --m; } } for (int u = 1; u <= n1 && m > 0; ++u) { for (int v = 1; v <= n2 && m > 0; ++v) { if (0 <= v - u && v - u <= 1) continue; std::cout << u << " " << v + n1 << "\n"; --m; } } } int main() { std::cin.tie(nullptr); std::ios::sync_with_stdio(false); solve(); return 0; }