Codeforces 567B:Berland National Library(模拟)
time limit per test : 1 second
memory limit per test : 256 megabytes
input : standard input
output : standard output
Problem Description
Berland National Library has recently been built in the capital of Berland. In addition, in the library you can take any of the collected works of Berland leaders, the library has a reading room.
Today was the pilot launch of an automated reading room visitors' accounting system! The scanner of the system is installed at the entrance to the reading room. It records the events of the form "reader entered room", "reader left room". Every reader is assigned a registration number during the registration procedure at the library — it's a unique integer from \(1\) to \(10^6\). Thus, the system logs events of two forms:
- "\(+\ r_i\)" — the reader with registration number \(r_i\) entered the room;
- "\(-\ r_i\)" — the reader with registration number l\(r_i\) left the room.
The first launch of the system was a success, it functioned for some period of time, and, at the time of its launch and at the time of its shutdown, the reading room may already have visitors.
Significant funds of the budget of Berland have been spent on the design and installation of the system. Therefore, some of the citizens of the capital now demand to explain the need for this system and the benefits that its implementation will bring. Now, the developers of the system need to urgently come up with reasons for its existence.
Help the system developers to find the minimum possible capacity of the reading room (in visitors) using the log of the system available to you.
Input
The first line contains a positive integer \(n (1 ≤ n ≤ 100)\) — the number of records in the system log. Next follow n events from the system journal in the order in which the were made. Each event was written on a single line and looks as ""\(+\ r_i\) or "\(-\ r_i\)", where \(r_i\) is an integer from \(1\) to \(10^6\), the registration number of the visitor (that is, distinct visitors always have distinct registration numbers).
It is guaranteed that the log is not contradictory, that is, for every visitor the types of any of his two consecutive events are distinct. Before starting the system, and after stopping the room may possibly contain visitors.
Output
Print a single integer — the minimum possible capacity of the reading room.
Examples
input
6
+ 12001
- 12001
- 1
- 1200
+ 1
+ 7
output
3
input
2
- 1
- 2
output
2
input
2
+ 1
- 1
output
1
题意
给出\(n\)个进出图书馆的人的编号,问图书馆的容量最小可以是多少
思路
\(res\)和\(ans\)分别代表当前图书馆的人数和图书馆的容量
如果编号为\(a_i\)的人出去了,并且\(a_i\)没有在之前出现过,那么图书馆的容量增加\(1\),如果出现过,当前图书馆的人数减\(1\)
当进来人的时候,当前图书馆的人数增加\(1\),如果\(res>ans\),那么图书馆的容量也加\(1\)
代码
#include <bits/stdc++.h>
#define ll long long
#define ull unsigned long long
#define ms(a,b) memset(a,b,sizeof(a))
const int inf=0x3f3f3f3f;
const ll INF=0x3f3f3f3f3f3f3f3f;
const int maxn=1e6+10;
const int mod=1e9+7;
const int maxm=1e3+10;
using namespace std;
struct wzy
{
	string opt;
	int id;
}p[maxn];
int main(int argc, char const *argv[])
{
    #ifndef ONLINE_JUDGE
        freopen("/home/wzy/in", "r", stdin);
        freopen("/home/wzy/out", "w", stdout);
        srand((unsigned int)time(NULL));
    #endif
    ios::sync_with_stdio(false);
    cin.tie(0);
    int n;
    cin>>n;
    map<int,int>mp;
    for(int i=1;i<=n;i++)
    	cin>>p[i].opt>>p[i].id;
    // 图书馆的总容量
    int ans=0;
    // 当前图书馆的人数
    int res=0;
    for(int i=1;i<=n;i++)
    {
    	if(p[i].opt=="-")
    	{
    		if(!mp[p[i].id])
    			ans++;
    		else
    			res--;
    	}
	    if(p[i].opt=="+")
	    {
	    	res++;
	    	if(res>ans)
	    		ans++;
	    	mp[p[i].id]=1;
	    }
    }
    cout<<ans<<endl;
    #ifndef ONLINE_JUDGE
        cerr<<"Time elapsed: "<<1.0*clock()/CLOCKS_PER_SEC<<" s."<<endl;
    #endif
    return 0;
}
Codeforces 567B:Berland National Library(模拟)的更多相关文章
- CodeForces 567B  Berland National Library
		Description Berland National Library has recently been built in the capital of Berland. In addition, ... 
- CodeForces 567B Berland National Library     hdu-5477   A Sweet Journey
		这类题一个操作增加多少,一个操作减少多少,求最少刚开始为多少,在中途不会出现负值,模拟一遍,用一个数记下最大的即可 #include<cstdio> #include<cstring ... 
- Codeforces Round #Pi (Div. 2) B. Berland National Library 模拟
		B. Berland National LibraryTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contes ... 
- Codeforces B - Berland National Library
		B. Berland National Library time limit per test 1 second memory limit per test 256 megabytes input s ... 
- Codeforces Round #Pi (Div. 2) B. Berland National Library set
		B. Berland National LibraryTime Limit: 2 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest ... 
- 构造 Codeforces Round #Pi (Div. 2) B. Berland National Library
		题目传送门 /* 题意:给出一系列读者出行的记录,+表示一个读者进入,-表示一个读者离开,可能之前已经有读者在图书馆 构造:now记录当前图书馆人数,sz记录最小的容量,in数组标记进去的读者,分情况 ... 
- Codeforces Round #Pi (Div. 2) B  Berland National Library
		B. Berland National Library time limit per test1 second memory limit per test256 megabytes inputstan ... 
- Berland National Library
		题目链接:http://codeforces.com/problemset/problem/567/B 题目描述: Berland National Library has recently been ... 
- CodeForces.158A Next Round (水模拟)
		CodeForces.158A Next Round (水模拟) 题意分析 校赛水题的英文版,坑点就是要求为正数. 代码总览 #include <iostream> #include &l ... 
随机推荐
- Yarn 公平调度器案例
			目录 公平调度器案例 需求 配置多队列的公平调度器 1 修改yarn-site.xml文件,加入以下从参数 2 配置fair-scheduler.xml 3 分发配置文件重启yarn 4 测试提交任务 ... 
- 备忘录:关于.net程序连接Oracle数据库
			目录 关于使用MSSM访问Oracle数据库 关于. net 程序中连接Oracle数据库 志铭-2021年12月7日 21:22:15 关于使用MSSM访问Oracle数据库 安装访问接口组件:Or ... 
- Linux基础命令---ntpq查询时间服务器
			ntpq ntpq指令使用NTP模式6数据包与NTP服务器通信,能够在允许的网络上查询的兼容的服务器.它以交互模式运行,或者通过命令行参数运行. 此命令的适用范围:RedHat.RHEL.Ubuntu ... 
- electron搭建开发环境
			环境:windons10, nodev14.17.1, vscode md a_star cd a_star npm i -g yarn yarn config set ELECTRON_MIRROR ... 
- springboot-使用AOP日志拦截实现
			一 前言 借助spring的AOP功能,我们可以将AOP应用至全局异常处理,全局请求拦截等,本篇文章的核心功能就是使用AOP实现日志记录,比如哪些用户进行了哪些操作,对于一个成功的项目这是必须记录的, ... 
- 【力扣】有序矩阵中第K小的元素
			给定一个 n x n 矩阵,其中每行和每列元素均按升序排序,找到矩阵中第 k 小的元素.请注意,它是排序后的第 k 小元素,而不是第 k 个不同的元素. 示例: matrix = [ [ 1, 5, ... 
- java多线程5:线程间的通信
			在多线程系统中,彼此之间的通信协作非常重要,下面来聊聊线程间通信的几种方式. wait/notify 想像一个场景,A.B两个线程操作一个共享List对象,A对List进行add操作,B线程等待Lis ... 
- Jenkins分布式与并行
			目录 一.简介 二.agent 通过JNLP协议增加agent 通过Swarm插件增加agent agent部分详解 三.agent放入Docker 使用Docker 配置Docker私有仓库 四.并 ... 
- <转>网络爬虫原理
			网络爬虫是捜索引擎抓取系统的重要组成部分.爬虫的主要目的是将互联网上的网页下载到本地形成一个或联网内容的镜像备份.这篇博客主要对爬虫以及抓取系统进行一个简单的概述. 一.网络爬虫的基本结构及工作流程 ... 
- 保留重复项(Power Query 之 M 语言)
			数据源: "姓名""基数""个人比例""个人缴纳""公司比例""公司缴纳"&qu ... 
