Codeforces Round #558 B2. Cat Party (Hard Edition)
题面:
题目描述:
题目分析:
1.每个不同的数字只出现1次,例:1,2,3,4,52.只有一种数字,例:1,1,1,1,13.只有一种数字出现1次,其他数字出现的次数相同,例:1,1,1,2,2,2,34.有一种数字出现的次数比其他数字都多出1次,例:1,1,2,2,3,3,3
我们开一个叫same_cnt的数组,那么对于这组数据:1,1,2,2,3,3,4,4,4其中same_cnt[2] = 3(因为数字1,2,3的数量是2,共3个)same_cnt[3] = 1(因为数字4的数量是3,共1个)
1 #include <bits/stdc++.h>
2 using namespace std;
3 const int maxn = 1e5+5;
4 int u[maxn];
5 int cnt[maxn];
6 int same_cnt[maxn];
7
8 int main(){
9 int n;
10 scanf("%d", &n);
11 for(int i = 1; i <= n; i++){
12 scanf("%d", &u[i]);
13 }
14
15 int res = 0;
16 int mx = 0;
17 for(int i = 1; i <= n; i++){
18 cnt[u[i]]++;
19 same_cnt[cnt[u[i]]-1]--;
20 same_cnt[cnt[u[i]]]++;
21
22 mx = max(mx, cnt[u[i]]); //小技巧,自己领会一下
23 int ok = 0;
24
25 if(same_cnt[1] == i) ok = 1; //第一种情况:数量为1的有i个
26 else if(same_cnt[i] == 1) ok = 1; //第二种情况:数量为i的有1个
27 //第三种情况
28 else if(same_cnt[1] == 1 && same_cnt[mx]*mx == i-1) ok = 1;
29 //第四种情况
30 else if(same_cnt[mx] == 1 && same_cnt[mx-1]*(mx-1) == i-mx) ok = 1;
31
32 if(ok) res = i;
33 }
34
35 printf("%d\n", res);
36 return 0;
37 }
Codeforces Round #558 B2. Cat Party (Hard Edition)的更多相关文章
- Codeforces Round #558 (Div. 2)
		目录 Codeforces Round #558 (Div. 2) 题解 A Eating Soup B Cat Party C Power Transmission D Mysterious Cod ... 
- Codeforces Round #558 (Div. 2)-Cat Party (Hard Edition)-(前缀和 + 模拟)
		http://codeforces.com/problemset/problem/1163/B2 题意:有n天,每天有一个颜色,截取前x天,随便抽掉一天,使剩下的各个颜色出现的次数相等. 解题,也可以 ... 
- Codeforces Round 558(Div 2)题解
		这场比赛没有打,后来和同学们一起开了场镜像打…… B是SB题结果WA了5发…… C是SB题结果差5min调出……虽然中间有个老师讲题吃掉了1h D是比较神仙的题(2200),但是做出来了?算是比较超常 ... 
- Codeforces Round #558 (Div. 2)B(SET,模拟)
		#include<bits/stdc++.h>using namespace std;int a[100007];int cnt[100007];int main(){ int n; ... 
- Codeforces Round #558 (Div. 2)C(计算几何,排列组合,模拟)
		#include<bits/stdc++.h>using namespace std;typedef struct{ double k,b;}node;node k[1000007];bo ... 
- Codeforces Round #351 (VK Cup 2016 Round 3, Div. 2 Edition) B. Problems for Round 水题
		B. Problems for Round 题目连接: http://www.codeforces.com/contest/673/problem/B Description There are n ... 
- Codeforces Round #351 (VK Cup 2016 Round 3, Div. 2 Edition) B
		B. Problems for Round time limit per test 2 seconds memory limit per test 256 megabytes input standa ... 
- Codeforces Round #351 (VK Cup 2016 Round 3, Div. 2 Edition)只有A题和B题
		连接在这里,->点击<- A. Bear and Game time limit per test 2 seconds memory limit per test 256 megabyte ... 
- [Educational Codeforces Round 16]D. Two Arithmetic Progressions
		[Educational Codeforces Round 16]D. Two Arithmetic Progressions 试题描述 You are given two arithmetic pr ... 
随机推荐
- 多线程之ThreadLocal类
			深入研究java.lang.ThreadLocal类 0.前言 ThreadLocal(线程变量副本)Synchronized实现内存共享,ThreadLocal为每个线程维护一个本地变量.采用空间换 ... 
- 3.keepalived+脚本实现nginx高可用
			标题 : 3.keepalived+脚本实现nginx高可用 目录 : Nginx 序号 : 3 else exit 0 fi else exit 0 fi - 需要保证脚本有执行权限,可以使用chm ... 
- cookie,session,token之间的联系与区别
			发展史 1.很久很久以前,Web 基本上就是文档的浏览而已, 既然是浏览,作为服务器, 不需要记录谁在某一段时间里都浏览了什么文档,每次请求都是一个新的HTTP协议, 就是请求加响应, 尤其是我不用 ... 
- window.navigator All In One
			window.navigator All In One navigator "use strict"; /** * * @author xgqfrms * @license MIT ... 
- 微信公众号 webfullstack
			微信公众号 webfullstack weixin refs https://mp.weixin.qq.com/cgi-bin/loginpage?t=wxm2-login&lang=zh_C ... 
- UX & feedback & instant visual feedback
			UX & feedback & instant visual feedback Select an element on the page https://ant.design/com ... 
- Flutter 1.5
			Flutter 1.5 Flutter SDK https://flutter.dev/docs/get-started/install/windows Android SDK This instal ... 
- qt 向窗口发送消息,键盘输入事件
			#include <windows.h> #include <QtDebug> #include <locale> #include <tchar.h> ... 
- 在.NET中使用Apache Kafka(一)
			曾经在你的应用程序中使用过异步处理吗?在处理不需要立即执行的任务时,异步代码似乎是不可避免的.Apache Kafka是最常用和最健壮的开源事件流平台之一.许多公司和开发者利用它的强大功能来创建高性 ... 
- js异步回调Async/Await与Promise区别 新学习使用Async/Await
			Promise,我们了解到promise是ES6为解决异步回调而生,避免出现这种回调地狱,那么为何又需要Async/Await呢?你是不是和我一样对Async/Await感兴趣以及想知道如何使用,下面 ... 
