結果
問題 |
No.366 ロボットソート
|
ユーザー |
![]() |
提出日時 | 2020-11-10 01:01:35 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 714 bytes |
コンパイル時間 | 2,073 ms |
コンパイル使用メモリ | 174,176 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-07-22 17:06:55 |
合計ジャッジ時間 | 2,293 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 23 |
ソースコード
#include <bits/stdc++.h> using namespace std; int main(){ int N, K; cin >> N >> K; vector<int> a(N); for (int i = 0; i < N; i++){ cin >> a[i]; } vector<vector<int>> b(K); for (int i = 0; i < N; i++){ b[i % K].push_back(a[i]); } int ans = 0; for (int i = 0; i < K; i++){ int cnt = b[i].size(); for (int j = 0; j < cnt; j++){ for (int k = j + 1; k < cnt; k++){ if (b[i][j] > b[i][k]){ ans++; } } } sort(b[i].begin(), b[i].end()); } for (int i = 0; i < N; i++){ a[i] = b[i % K][i / K]; } for (int i = 0; i < N - 1; i++){ if (a[i] > a[i + 1]){ cout << -1 << endl; return 0; } } cout << ans << endl; }