社区讨论

52求助

P2896[USACO08FEB] Eating Together S参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@lv7qo6ry
此快照首次捕获于
2024/04/20 14:49
2 年前
此快照最后确认于
2024/04/20 16:52
2 年前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int n,a[100010],f[100010],ans,ans1,ans2,cnt;
int main(){
	cin>>n;
	for(int i=1;i<=n;i++) cin>>a[i];
	for(int i=1;i<=n;i++){
		f[i]=1;
		for(int j=1;j<=i-1;j++){
			if(a[i]<a[j]){
				f[i]=max(f[i],f[j]+1);
				cnt++;
			}				
		}
		ans1=max(ans1,f[i]);
	}
	//cnt--;
	//ans1=n-cnt;
	//memset(a,0,sizeof a);
	cnt=0;
	for(int i=n;i>=1;i--){
		f[i]=1;
		for(int j=i+1;j<=n;j++){
			if(a[i]<a[j]){
				f[i]=max(f[i],f[j]+1);
				cnt++;
			}				
		}
		ans2=max(ans2,f[i]);
	}
	//cnt--;
	//ans2=n-cnt;
	ans=min(ans1-1,ans2-1);
	cout<<ans<<endl;
	return 0;
}

回复

0 条回复,欢迎继续交流。

正在加载回复...