結果
問題 | No.334 門松ゲーム |
ユーザー | __tatamo__ |
提出日時 | 2016-02-11 22:56:45 |
言語 | C++11 (gcc 13.3.0) |
結果 |
RE
|
実行時間 | - |
コード長 | 1,378 bytes |
コンパイル時間 | 414 ms |
コンパイル使用メモリ | 55,252 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-09-22 04:01:12 |
合計ジャッジ時間 | 3,043 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | RE | - |
testcase_01 | RE | - |
testcase_02 | RE | - |
testcase_03 | RE | - |
testcase_04 | RE | - |
testcase_05 | RE | - |
testcase_06 | RE | - |
testcase_07 | RE | - |
testcase_08 | RE | - |
testcase_09 | RE | - |
testcase_10 | RE | - |
testcase_11 | RE | - |
testcase_12 | RE | - |
testcase_13 | RE | - |
testcase_14 | RE | - |
testcase_15 | RE | - |
コンパイルメッセージ
main.cpp: In function ‘int main()’: main.cpp:70:14: warning: ‘t’ may be used uninitialized [-Wmaybe-uninitialized] 70 | int* t; | ^
ソースコード
#include<iostream> #include<string> #define MAX (2000000000) using namespace std; int n; int* k; int result[3] = {-1,-1,-1}; bool flg_end = false; bool check_K(int* t){ /*for(int i=0;i<3;i++){ cout << t[i]; } cout << " "; for(int i=0;i<3;i++){ cout << k[t[i]]; }*/ int a,b,c; a = t[0], b = t[1], c = t[2]; if(k[a] < k[b] && k[b] < k[c]) return false; if(k[a] > k[b] && k[b] > k[c]) return false; return true; } bool check(int* t, int len){ // check if able to make K numbers if(len<3) return false; int d = k[t[0]]<k[t[1]]?1:-1; for(int i=1;i<len;i++){ if(k[t[i-1]]*d>k[t[i]]*d) return true; } return false; } void solve_3(int* t, int c, int index){ if(flg_end) return; if(c == 3) { if(check(t,3)){ int* tmp = new int[n-3]; int j=0; for(int i=0;i<n;i++){ if(i!=t[0]&&i!=t[1]&&i!=t[2])tmp[j++] = k[i]; } if(!check(tmp,n-3)){ for(int i=0;i<3;i++) result[i] = t[i]; flg_end = true; } delete[] tmp; } } else { for(int i=index;i<n;i++){ int* tmp = new int[3]; for(int ii=0;ii<3;ii++) tmp[ii] = t[ii]; tmp[c] = i; solve_3(tmp,c+1,i+1); delete[] tmp; } } } int main(){ cin >> n; k = new int[n]; for(int i=0;i<n;i++){ cin >> k[i]; } int* t; solve_3(t,0,0); if(result[0] == -1) cout << "-1" << endl; else cout << result[0] << " " << result[1] << " " << result[2] << endl; return 0; }