牛客春招刷题训练营 - 2025.5.14 题解

活动地址:牛客春招刷题训练营 - 编程打卡活动

Easy 分组

简要题意

个同学进行分组,要求每组不少于 人,问最多分几组。

Solution

显然答案就是

Code

void R()
{
	int n;
	cin>>n;
	cout<<n/3;
	return;
}

Medium 小欧的数组修改

简要题意

给一个数组,你可以选择一个数进行修改,之后求数组众数出现次数最大值。

Solution

如果数组内只有一种数,答案就是 ;否则就是原数组众数出现次数

Code

void R()
{
	int n,ans=0;
	cin>>n;
	map<int,int> cnt;
	for (int i=0;i<n;i++)
	{
		int x;
		cin>>x;
		cnt[x]++;
		ans=max(ans,cnt[x]);
	}
	if (ans<n) ans++;
	cout<<ans;
	return;
}

Hard 合唱队形

简要题意

问至少删去多少个数,可以使给定数组先严格上升后严格下降(允许全程严格上升或下降)。

Solution

我们把先严格上升后严格下降的序列称为合唱序列。

题目相当于求 减去数组中最长合唱序列长度。

dp 出从前往后/从后往前每个位置的最长上升子序列

就是以位置 为最大值的最大合唱序列长度,取 即为答案。

Code

void R()
{
	int n,ans=0;
	cin>>n;
	vector<int> t(n),f(n),g(n);
	for (int &x:t) cin>>x;
	for (int i=0;i<n;i++)
	{
		f[i]=1;
		for (int j=0;j<i;j++)
			if (t[j]<t[i])
				f[i]=max(f[i],f[j]+1);
	}
	for (int i=n-1;i>=0;i--)
	{
		g[i]=1;
		for (int j=n-1;j>i;j--)
			if (t[i]>t[j])
				g[i]=max(g[i],g[j]+1);
	}
	for (int i=0;i<n;i++)
		ans=max(ans,f[i]+g[i]-1);
	cout<<n-ans;
	return;
}
#牛客春招刷题训练营#
全部评论

相关推荐

05-21 15:47
门头沟学院 Java
浪漫主义的虹夏:项目有亮点吗,第一个不是纯玩具项目吗,项目亮点里类似ThreadLocal,Redis储存说难听点是花几十分钟绝大部分人都能学会,第二个轮子项目也没体现出设计和技术,想实习先沉淀,好高骛远的自嗨只会害了自己
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务