90分 #1WA蒟蒻很茫然
查看原帖
90分 #1WA蒟蒻很茫然
393674
jixiang楼主2021/5/26 15:54
#include<bits/stdc++.h>
using namespace std;
const int MAXN =100000;
int r,c;
int f[MAXN];
int num[MAXN];
int ans;
int dir[5];

struct node{
	int high,num;
	void input(int x)
	{
		scanf("%d",&high);
		num=x;
	}
	
}a[100009];

bool cmp(node x,node y)
{
	return x.high<y.high;
}

int main()
{
	cin>>r>>c;
	int x;
	
	dir[1]=1;dir[2]=-1;
	dir[3]=c;dir[4]=-c;
	
	for(int i=1;i<=r*c;i++)
	{
		a[i].input(i);
		num[i]=a[i].high;
		f[i]=1;
	}
	
	
	sort(a+1,a+1+r*c,cmp);
	
	
	for(int i=1;i<=r*c;i++)
	{
		x=a[i].num;
		
		for(int k=1;k<=4;k++)
		{
			if(x+dir[k]<=0||x+dir[k]>r*c)continue;
			if(x%c==0&&k==1)continue;
			if(x-1%c==0&&k==2)continue;
			
			if(num[x+dir[k]]<num[x])
			f[x]=max(f[x],f[x+dir[k]]+1);
		} 
	}
	
	for(int i=1;i<=r*c;++i)ans=max(ans,f[i]);
	cout<<ans;

	//for(int i=1;i<=r*c;i++)cout<<num[i]<<" "<<f[i]<<endl;
	
	
} 
2021/5/26 15:54
加载中...