B - Cat Party (Easy Edition) CodeForces - 1163B1B2(思维)

编程入门 行业动态 更新时间:2024-10-23 16:19:17

B - Cat Party (Easy Edition) CodeForces - 1163B1B2(<a href=https://www.elefans.com/category/jswz/34/1770010.html style=思维)"/>

B - Cat Party (Easy Edition) CodeForces - 1163B1B2(思维)

B - Cat Party (Easy Edition) CodeForces - 1163B1&&B2

题目大意:
从Shiro 搬到新家开始的n天里,每天都会有一个朋友来到Shiro 家玩。第 i 天来的朋友戴了一条彩色的丝带,色号为ui。Shiro 想要找到最长的天数x,满足在前x天中,删除其中恰好一天的丝带色号,使得在剩下的x - 1天中每种色号出现的天数都一样。
例如,每一天出现的丝带色号如下 [2, 2, 1, 1, 5, 4, 4, 5]。这里是 8 天连续出现的色号序列,最长的天数 x = 7,因为在前7天中删除第5天的色号5,那么在剩下的6天里,每种丝带色号出现的天数都相同。
请你帮助Shiro 找出这样的最长天数 x。

B1和B2数据不一样
B1:n(天数)0<=n<=1e5 x(彩带编号) 1<=x<=10
B2: 0<=n<=1e5 1<=x<=1e5

思路:写了7发,wa6发,最后改了过来,果不其然T了,唉!!
看了看网上的代码(短小精悍),思路很新奇(鉴于本人的浅薄的知识)。复杂度居然O(N),流弊格拉斯。
具体写法,开两个map,一个记录这个数出现的次数,第二个记录次数出现的个数(有点绕),为什么这样就行呢?因为题目要求的这个出现次数,不一定是连续的。然后判断次数*次数出现的次数是否等与i(天数),和i-1,且不断更新最大天数。

无思维不算法,道阻且长,冲冲冲!

#include <iostream>
#include <cstdio>
#include<cstdlib>
#include <fstream>
#include <algorithm>
#include <cmath>
#include <deque>
#include <vector>
#include <queue>
#include <string>
#include <cstring>
#include <map>
#include<time.h>
#include <stack>
#include <list>
#include <set>
#include <sstream>
#include <iterator>
using namespace std;
#define FOPI freopen("input.in", "r", stdin)
#define DOPI freopen("output.out", "w", stdout)
#define ll long long int
#define fro(i,a,n) for(ll i=a;i<n;i++)
#define pre(i,a,n) for(ll i=n-1;i>=a;i--)
#define mem(a,b) memset(a,b,sizeof(a))
#define ls l,mid,rt<<1
#define rs mid+1,r,rt<<1|1
#define fi first
#define se second
#define s_d(a) scanf("%d",&a)
#define s_lld(a) scanf("%lld",&a)
#define s_s(a) scanf("%s",a)
#define s_ch(a) scanf("%c",&a)
typedef pair<ll,ll> P;
ll gcd(ll a,ll b){return b==0?a:gcd(b,a%b);}
const double PI = 3.1415926535897932;
const double EPS=1e-6;
const int INF=0x3f3f3f3f;
const int maxn = 2e5+100;
int lowbit(int x){return x&(-x);}
int main()
{ios::sync_with_stdio(0);map<int,int> mp1,mp2;int n,a;cin>>n;int ans=1;fro(i,1,n+1){cin>>a;int s1,s2;mp1[a]++;s1=mp1[a];mp2[mp1[a]]++;s2=mp2[mp1[a]];if(s1*s2==i&&i!=n)ans=i+1;if(s1*s2==i-1)ans=i;}cout<<ans<<endl;return 0;
}
/*
11
2 2 4 4 3 3 3 5 5 5 6*/

更多推荐

B - Cat Party (Easy Edition) CodeForces - 1163B1B2(思维)

本文发布于:2023-07-28 15:26:14,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1235598.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:思维   Easy   Party   Cat   Edition

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!