結果
| 問題 | No.629 グラフの中に眠る門松列 | 
| コンテスト | |
| ユーザー |  gazelle | 
| 提出日時 | 2018-01-05 21:38:50 | 
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 3 ms / 4,000 ms | 
| コード長 | 1,170 bytes | 
| コンパイル時間 | 1,126 ms | 
| コンパイル使用メモリ | 104,380 KB | 
| 実行使用メモリ | 5,248 KB | 
| 最終ジャッジ日時 | 2024-12-23 06:27:38 | 
| 合計ジャッジ時間 | 2,497 ms | 
| ジャッジサーバーID (参考情報) | judge1 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 6 | 
| other | AC * 36 | 
ソースコード
#include<iostream>
#include<iomanip>
#include<math.h>
#include<vector>
#include<algorithm>
#include<set>
#include<map>
#include<queue>
#include<stack>
#include<string>
#include<bitset>
#include<random>
#define INF 1000000000ll
#define MOD 1000000007ll
#define EPS 1e-10
#define REP(i,m) for(long long i=0; i<m; i++)
#define FOR(i,n,m) for(long long i=n; i<m; i++)
#define DUMP(a) for(long long dump=0; dump<(ll)a.size(); dump++) { cout<<a[dump]; if(dump!=(ll)a.size()-1) cout<<" "; else cout<<endl; }
#define ALL(v) v.begin(),v.end()
#define pb push_back
using namespace std;
typedef long long ll;
typedef pair<ll, ll> P;
typedef long double ld;
vector<ll> a;
vector<vector<ll>> adj;
int main() {
	cin.tie(0);
	ios::sync_with_stdio(false);
	ll n,m;
	cin>>n>>m;
	a.resize(n);
	adj.resize(n);
	REP(i,n) cin>>a[i];
	REP(i,m) {
		ll u,v;
		cin>>u>>v;
		u--;
		v--;
		adj[u].pb(v);
		adj[v].pb(u);
	}
	REP(i,n) {
		set<ll> sita,ue;
		REP(j,(ll)adj[i].size()) {
			if(a[adj[i][j]]<a[i]) sita.insert(a[adj[i][j]]);
			if(a[adj[i][j]]>a[i]) ue.insert(a[adj[i][j]]);
		}
		if((ll)sita.size()>=2||(ll)ue.size()>=2) {
			cout<<"YES"<<endl;
			return 0;
		}
	}
	cout<<"NO"<<endl;
}
            
            
            
        