結果
問題 |
No.365 ジェンガソート
|
ユーザー |
![]() |
提出日時 | 2016-04-29 22:53:33 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,128 bytes |
コンパイル時間 | 663 ms |
コンパイル使用メモリ | 80,504 KB |
実行使用メモリ | 13,632 KB |
最終ジャッジ日時 | 2024-10-04 18:33:29 |
合計ジャッジ時間 | 4,338 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 10 WA * 6 TLE * 1 -- * 24 |
ソースコード
#include <algorithm> #include <climits> #include <cmath> #include <cstdio> #include <cstdlib> #include <cstring> #include <functional> #include <iostream> #include <map> #include <ostream> #include <queue> #include <set> #include <stack> #include <string> #include <vector> #define INF 1000000000 #define rep(i,a,b) for (int i=(a);i<(b);i++) #define rev(i,a,b) for (int i=(a)-1;i>=b;i--) using namespace std; typedef long long ll; typedef pair<int, int> pii; typedef queue<int> qi; typedef vector<int> vi; typedef vector<string> vs; int dx[4] = { 0, 1, 0, -1 }; int dy[4] = { 1, 0, -1, 0 }; int n; int a[100000]; int main() { cin.tie(0); ios::sync_with_stdio(false); cin >> n; rep(i,0,n) cin >> a[i]; int ans = 0; rev(i,n,0) { if(i+1 == a[i]) continue; else if(i+1 > a[i]) { int num = 1, j = i-1; while(i+1 != a[j] && j > 0) { j--; num++; } int cnt = 0; while(cnt < num) { int max = i; rev(k, i, j+1) if(a[max] < a[k]) max = k; int tmp = a[max]; rev(k, max+1, 0) a[k] = a[k-1]; a[0] = tmp; cnt++; ans++; j++; } } } cout << ans << endl; return 0; }