답안 #734076

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
734076 2023-05-01T16:03:32 Z Amaarsaa 팬케이크 정렬 (NOI12_pancake) C++14
12 / 25
1000 ms 212 KB
#include<bits/stdc++.h>

using namespace std;
using ll = long long;
ll n, ans, p, j, s;
void Dfs(ll a[], ll  moves) {
	if ( moves < ans) return;
	if ( moves == 0) return ;
	s = n;
	
	for (ll i = 1; i <= n; i ++) {
		if ( a[i] == (n - i + 1)) s --;
	}
	if ( s == 0) {
		ans =max (ans, moves);
		return;
	}
	for (ll i = 1; i <= n; i ++) {
		reverse(a + i,a +n + 1);
		Dfs(a, moves - 1);
		reverse(a + i, a + n + 1);
	}
	return ;
}
int main() {
	ll i, t, r;
	cin >> t;
	
	while ( t --) {
		cin >> n;
		ans = -1e9;
		ll a[n + 2];
		vector < pair < ll, ll > > v;
		for (i = 1; i <= n; i ++) {
			cin >> a[i];
			v.push_back(make_pair(a[i], i));
		}
		sort (v.begin(), v.end());
		for ( i = 0; i < n; i ++) {
			a[v[i].second ] = i + 1;
		}
		Dfs(a, 2*n);
		cout << 2 * n - ans << endl;
	}
}

Compilation message

pancake.cpp: In function 'int main()':
pancake.cpp:26:11: warning: unused variable 'r' [-Wunused-variable]
   26 |  ll i, t, r;
      |           ^
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 212 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 212 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 212 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1072 ms 212 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1046 ms 212 KB Time limit exceeded
2 Halted 0 ms 0 KB -