답안 #734077

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
734077 2023-05-01T16:07:32 Z Amaarsaa 팬케이크 정렬 (NOI12_pancake) C++14
12 / 25
21 ms 304 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 =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 = 0;
		ll a[n + 2], b[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;
		}
		for ( i = 1; i <= n; i ++) {
			if ( a[i] != (n - i + 1)) {
				for ( j = i; j <= n; j ++) {
					if ( a[j] == n - i + 1) r= j;
				}
				
				if ( r == n) ans ++;
				else ans += 2;
				reverse(a + r , a + n + 1);
				reverse(a + i, a + n + 1);
			}
		}
		for ( i = 1; i <= n; i ++) a[i] = b[i];
		Dfs(a, 0);
		cout << ans << endl;
	}
}

Compilation message

pancake.cpp: In function 'int main()':
pancake.cpp:50:17: warning: 'r' may be used uninitialized in this function [-Wmaybe-uninitialized]
   50 |     reverse(a + r , a + n + 1);
      |                 ^
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 212 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 212 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 212 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Incorrect 1 ms 212 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 21 ms 304 KB Output isn't correct
2 Halted 0 ms 0 KB -