結果
問題 |
No.360 増加門松列
|
ユーザー |
![]() |
提出日時 | 2016-04-25 09:15:18 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 459 ms / 2,000 ms |
コード長 | 647 bytes |
コンパイル時間 | 473 ms |
コンパイル使用メモリ | 57,176 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-12-24 04:33:49 |
合計ジャッジ時間 | 8,429 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 22 |
ソースコード
#include<iostream> #include<algorithm> using namespace std; bool jud(int a,int b,int c){ return a<c&&a!=b&&b!=c&&a!=c&&(min(a,min(b,c))==b||max(a,max(b,c))==b); } int main(){ int D[7]; for(int i=0;i<7;i++) cin>>D[i]; for(int i=123456;i<10000000;i++){ int a[7]; int b=i; for(int j=0;j<7;j++) a[6-j]=b%10,b/=10; bool f=true; for(int j=0;j<7;j++){ if(a[j]<0||a[j]>6) f=false; for(int k=0;k<7;k++){ if(j!=k&&a[k]==a[j]) f=false; } } if(f){ f=true; for(int j=0;j<7-2;j++){ if(!jud(D[a[j]],D[a[j+1]],D[a[j+2]])) f=false; } if(f){ cout<<"YES"<<endl; return 0; } } } cout<<"NO"<<endl; }