제출 #666266

#제출 시각아이디문제언어결과실행 시간메모리
666266vuavisao팬케이크 정렬 (NOI12_pancake)C++14
0 / 25
1 ms468 KiB
#include<bits/stdc++.h> #pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") #define ll long long using namespace std; const int N = 8 + 10; bool cakeee(int* val); bool special_case_zero(); bool special_case_one(); bool special_case_two(); void solve(); int n; int a[N]; void solve() { cin >> n; for(int i = 1; i <= n; ++ i) cin >> a[i]; a[0] = 1000000000; if(special_case_zero()) { cout << 0; return; } if(special_case_one()) { cout << 1; return; } if(special_case_two()) { cout << 2; return; } assert(false); } int32_t main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); if (fopen("Cake.inp", "r")) { freopen("Cake.inp", "r", stdin); freopen("Cake.out", "w", stdout); } int t; cin >> t; while(t--) { solve(); cout << '\n'; } return 0; } bool special_case_zero() { return cakeee(a); } bool special_case_one() { int tmp[N]; for(int i = 1; i <= n; ++ i) { for(int j = 0; j <= n; ++ j) tmp[j] = a[j]; reverse(tmp + i + 1, tmp + n + 1); if(cakeee(tmp)) return true; } return false; } bool special_case_two() { int tmp[N]; for(int i = 1; i <= n; ++ i) { for(int j = 1; j <= n; ++ j) { for(int k = 0; k <= n; ++ k) tmp[k] = a[k]; reverse(tmp + i + 1, tmp + n + 1); reverse(tmp + j + 1, tmp + n + 1); if(cakeee(tmp)) return true; } } return false; } bool cakeee(int* val) { for(int i = 1; i <= n; ++ i) if(val[i] > val[i - 1]) return false; return true; } /// Code by vuavisao

컴파일 시 표준 에러 (stderr) 메시지

pancake.cpp: In function 'int32_t main()':
pancake.cpp:42:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   42 |         freopen("Cake.inp", "r", stdin);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
pancake.cpp:43:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   43 |         freopen("Cake.out", "w", stdout);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...