結果

問題 No.335 門松宝くじ
ユーザー fiordfiord
提出日時 2016-01-21 01:01:12
言語 C++11
(gcc 11.4.0)
結果
AC  
実行時間 419 ms / 2,000 ms
コード長 2,144 bytes
コンパイル時間 1,688 ms
コンパイル使用メモリ 172,408 KB
実行使用メモリ 4,348 KB
最終ジャッジ日時 2023-10-21 13:38:51
合計ジャッジ時間 5,324 ms
ジャッジサーバーID
(参考情報)
judge13 / judge11
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
4,348 KB
testcase_01 AC 2 ms
4,348 KB
testcase_02 AC 1 ms
4,348 KB
testcase_03 AC 2 ms
4,348 KB
testcase_04 AC 2 ms
4,348 KB
testcase_05 AC 106 ms
4,348 KB
testcase_06 AC 157 ms
4,348 KB
testcase_07 AC 282 ms
4,348 KB
testcase_08 AC 258 ms
4,348 KB
testcase_09 AC 418 ms
4,348 KB
testcase_10 AC 419 ms
4,348 KB
testcase_11 AC 419 ms
4,348 KB
testcase_12 AC 417 ms
4,348 KB
testcase_13 AC 417 ms
4,348 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
bool isKadomatsu(int a,int b,int c){
	if(a==b||b==c||c==a)	return false;
	int m=max(a,max(b,c)),M=min(a,min(b,c));
	if(b==m||b==M)	return true;
	return false;
}
struct segtree{
	vector<int> big,sml;
	int n;
	segtree(int x){
		n=1;
		while(n<x)	n<<=1;
	}
	void assign(vector<int> a){
		big.clear();	big.assign(2*n-1,INT_MIN);
		sml.clear();	sml.assign(2*n-1,INT_MAX);
		for(int i=0;i<(int)a.size();i++){
			int t=n-1+i;
			big[t]=sml[t]=a[i];
		}
		for(int i=n-2;i>=0;i--){
			big[i]=max(big[2*i+1],big[2*i+2]);
			sml[i]=min(sml[2*i+1],sml[2*i+2]);
		}
	}
	int maximum(int l,int r,int a,int b,int k){
		if(r<=a||b<=l)	return INT_MIN;
		if(a<=l&&r<=b)	return big[k];
		int vr=maximum(l,(l+r)/2,a,b,2*k+1);
		int vl=maximum((l+r)/2,r,a,b,2*k+2);
		return max(vr,vl);
	}
	int minimum(int l,int r,int a,int b,int k){
		if(r<=a||b<=l)	return INT_MAX;
		if(a<=l&&r<=b)	return sml[k];
		int vl=minimum(l,(l+r)/2,a,b,2*k+1);
		int vr=minimum((l+r)/2,r,a,b,2*k+2);
		return min(vl,vr);
	}
};
int main(){
	int n,m;	cin>>n>>m;
	int ans=0,score=0;
	segtree seg(n);
	for(int i=0;i<m;i++){
		vector<int> a(n);
		for(int j=0;j<n;j++)	cin>>a[j];
		seg.assign(a);
		int tmp=0;
		for(int j=0;j<n;j++){
			for(int k=j+1;k<n;k++){
				int add=0;
				int p;
				if(0<j){
					p=seg.maximum(0,seg.n,0,j,0);
					if(isKadomatsu(p,a[j],a[k])){
						add=max(max(a[j],a[k]),max(add,p));
					}
					p=seg.minimum(0,seg.n,0,j,0);
					if(isKadomatsu(p,a[j],a[k])){
						add=max(add,max(a[j],a[k]));
					}
				}
				if(j+1<k){
					p=seg.maximum(0,seg.n,j+1,k,0);
					if(isKadomatsu(a[j],p,a[k])){
						add=max(max(a[j],a[k]),max(add,p));
					}
					p=seg.minimum(0,seg.n,j+1,k,0);
					if(isKadomatsu(a[j],p,a[k])){
						add=max(add,max(a[j],a[k]));
					}
				}
				if(k+1<n){
					p=seg.maximum(0,seg.n,k+1,n,0);
					if(isKadomatsu(a[j],a[k],p)){
						add=max(max(a[j],a[k]),max(add,p));
					}
					p=seg.minimum(0,seg.n,k+1,n,0);
					if(isKadomatsu(a[j],a[k],p)){
						add=max(add,max(a[j],a[k]));
					}
				}
				tmp+=add;
			}
		}
		if(score<tmp){
			ans=i;	score=tmp;
		}
	}
	cout<<ans<<endl;
	return 0;
}
0