社区讨论

0分求调

P2362围栏木桩参与者 1已保存回复 0

讨论操作

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

当前回复
0 条
当前快照
1 份
快照标识符
@m2d6okuh
此快照首次捕获于
2024/10/17 18:54
去年
此快照最后确认于
2024/10/17 20:24
去年
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
const int N=25;
int n,m,a[N],dp[N],t,c,f[N];
int main()
{
	scanf("%d",&m);
	while(m--)
	{
		memset(dp,0,sizeof(dp));
		t=-1,c=0;
		scanf("%d",&n);
		for(int i=1;i<=n;i++) scanf("%d",&a[i]),dp[i]=f[i]=1;
		for(int i=1;i<=n;i++)
		{
			for(int j=1;j<=i;j++)
			{
				if(a[i]>a[j])
				{
					dp[i]=max(dp[i],dp[j]+1);
					f[i]=f[j];
				}
				if(a[i]==a[j]) f[i]+=f[j];
			}
		}
		for(int i=1;i<=n;i++)
		{
			if(t<dp[i])
			{
				t=dp[i];
				c=f[i];
			}
		}
		printf("%d %d\n",t,c);
	}
	return 0;
}

回复

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

正在加载回复...