【题解】序列划分

题意

给你一个序列,将其划分为几个子序列,要求每个子序列中的元素是不重复的。求最少可以把序列划分为多少个。

思路

由于这题并没有要求划分的具体方案也没有说需要子序列满足什么顺序。所以只用考虑不重复,那么根据贪心策略,我们只用考虑哪个元素出现次数是最多的,那么其出现次数就是最少的划分方案数。因为你必须将这重复最多的元素划分到不同的子序列中。

复杂度

时间复杂度

代码

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+5;
int vis[N];
int main()
{
    int n;
    scanf("%d",&n);
    int ans=0;
    for(int i=0;i<n;i++)
    {
        int v;
        scanf("%d",&v);
        vis[v]++;
        ans=max(ans,vis[v]);
    }
    printf("%d\n",ans);
    return 0;
}

全部评论

相关推荐

2025-12-15 19:41
已编辑
广东工业大学 前端工程师
smile丶snow:尽量保证的一张a4纸吧。为什么工作经历只有公司?如果项目经历是工作里面的,应该写到工作经历里的吧。没有写项目职责,项目全是一个人写的吗?标题大小也好怪。两个项目的分割看不出来是,它和那些项目成功字体是一样大的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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