Codeforces Round #527-D1. Great Vova Wall (Version 1)(思维+栈)
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output
Vova's family is building the Great Vova Wall (named by Vova himself). Vova's parents, grandparents, grand-grandparents contributed to it. Now it's totally up to Vova to put the finishing touches.
The current state of the wall can be respresented by a sequence aa of nn integers, with aiai being the height of the ii-th part of the wall.
Vova can only use 2×12×1 bricks to put in the wall (he has infinite supply of them, however).
Vova can put bricks horizontally on the neighboring parts of the wall of equal height. It means that if for some ii the current height of part iiis the same as for part i+1i+1, then Vova can put a brick there and thus increase both heights by 1. Obviously, Vova can't put bricks in such a way that its parts turn out to be off the borders (to the left of part 11 of the wall or to the right of part nn of it).
The next paragraph is specific to the version 1 of the problem.
Vova can also put bricks vertically. That means increasing height of any part of the wall by 2.
Vova is a perfectionist, so he considers the wall completed when:
- all parts of the wall has the same height;
- the wall has no empty spaces inside it.
Can Vova complete the wall using any amount of bricks (possibly zero)?
Input
The first line contains a single integer nn (1≤n≤2⋅1051≤n≤2⋅105) — the number of parts in the wall.
The second line contains nn integers a1,a2,…,ana1,a2,…,an (1≤ai≤1091≤ai≤109) — the initial heights of the parts of the wall.
Output
Print "YES" if Vova can complete the wall using any amount of bricks (possibly zero).
Print "NO" otherwise.
Examples
input
Copy
5
2 1 1 2 5
output
Copy
YES
input
Copy
3
4 5 3
output
Copy
YES
input
Copy
2
10 10
output
Copy
YES
input
Copy
3
1 2 3
output
Copy
NO
Note
In the first example Vova can put a brick on parts 2 and 3 to make the wall [2,2,2,2,5] and then put 3 bricks on parts 1 and 2 and 3 bricks on parts 3 and 4 to make it [5,5,5,5,5].
In the second example Vova can put a brick vertically on part 3 to make the wall [4,5,5], then horizontally on parts 2 and 3 to make it [4,6,6][4,6,6] and then vertically on part 1 to make it [6,6,6].
In the third example the wall is already complete.
题解:如果相邻的两堆差值为2的倍数则可以成对消去,这个过程可以用栈来模拟,最后判断如果剩余堆的数量大于一,输出NO即可
代码:
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<stack>
using namespace std;
int main() {
	stack<int>s;
	int n;
	cin>>n;
	for(int t=0; t<n; t++) {
		int k;
		scanf("%d",&k);
		if(s.empty()) {
			s.push(k);
		} else {
			if(abs(s.top()-k)%2==1) {
				s.push(k);
			} else {
				s.pop();
			}
		}
	}
	if(s.size()>1)
		cout<<"NO"<<endl;
	else {
		cout<<"YES"<<endl;
	}
	return 0;
}Codeforces Round #527-D1. Great Vova Wall (Version 1)(思维+栈)的更多相关文章
- Codeforces Round #527 (Div. 3) D1. Great Vova Wall (Version 1) 【思维】
		传送门:http://codeforces.com/contest/1092/problem/D1 D1. Great Vova Wall (Version 1) time limit per tes ... 
- CodeForces Round #527 (Div3)  D1. Great Vova Wall (Version 1)
		http://codeforces.com/contest/1092/problem/D1 Vova's family is building the Great Vova Wall (named b ... 
- D1. Great Vova Wall (Version 1)
		链接 [https://codeforces.com/contest/1092/problem/D1] 题意 给你n个位置墙的高度,现在你有2×1 砖块,你可以竖直或者水平放置 问你是否可以使得所有位 ... 
- Codeforces Round #527 (Div. 3)  C. Prefixes and Suffixes   (思维,字符串)
		题意:给你某个字符串的\(n-1\)个前缀和\(n-1\)个后缀,保证每个所给的前缀后缀长度从\([1,n-1]\)都有,问你所给的子串是前缀还是后缀. 题解:这题最关键的是那两个长度为\(n-1\) ... 
- Codeforces Round #527 (Div. 3) ABCDEF题解
		Codeforces Round #527 (Div. 3) 题解 题目总链接:https://codeforces.com/contest/1092 A. Uniform String 题意: 输入 ... 
- Codeforces Round #527 (Div. 3)
		一场div3... 由于不计rating,所以打的比较浪,zhy直接开了个小号来掉分,于是他AK做出来了许多神仙题,但是在每一个程序里都是这么写的: 但是..sbzhy每题交了两次,第一遍都是对的,结 ... 
- Codeforces Round #527 (Div. 3) D2. Great Vova Wall (Version 2) 【思维】
		传送门:http://codeforces.com/contest/1092/problem/D2 D2. Great Vova Wall (Version 2) time limit per tes ... 
- Codeforces Round #535 E2-Array and Segments (Hard version)
		Codeforces Round #535 E2-Array and Segments (Hard version) 题意: 给你一个数列和一些区间,让你选择一些区间(选择的区间中的数都减一), 求最 ... 
- Codeforces Round #620 F2. Animal Observation (hard version) (dp + 线段树)
		Codeforces Round #620 F2. Animal Observation (hard version) (dp + 线段树) 题目链接 题意 给定一个nm的矩阵,每行取2k的矩阵,求总 ... 
- CodeForces Round #527 (Div3) D2. Great Vova Wall (Version 2)
		http://codeforces.com/contest/1092/problem/D2 Vova's family is building the Great Vova Wall (named b ... 
随机推荐
- Linux学习之路(二)文件处理命令之下
			分区格式化: 一块分区想要使用的话,要格式化.格式化主要有两个工作,1,把分区分成等大小的数据块,每个数据块一般为4KB.2在分区之前建一个分区表,给第一个文件建一行相关数据,在分区表里保存了它的io ... 
- 介绍 Java 的内存泄漏
			java最明显的一个优势就是它的内存管理机制.你只需简单创建对象,java的垃圾回收机制负责分配和释放内存.然而情况并不像想像的那么简单,因为在Java应用中经常发生内存泄漏.脚本代码 本教程演示了什 ... 
- html5基本格式
			html5基本格式 学习要点: HTML5 文档的基本格式 2. 开发工具的基本操作 一. 文档基本格式 <!DOCTYPE html> 文档声明,告诉计算机这是一个HTML5文档. ... 
- python 3 - 写一个注册的程序,账号和密码都存在文件里面
			choice = input('请输入你的选择:1,注册2.删除用户3.登录') #注册 输入 账号 密码 密码确认 # #需要校验用户是否存在,两次输入的密码,是否一致,为空的情况 #账号和密码都存 ... 
- IntelliJ IDEA 的 project 和 module 区别与关系
			在IDEA 创建一个project,目录结构是这样的:在project下创建一个module之后目录结构是这样的: 简单的概括如下: IntelliJ系中的 Project 相当于Eclipse系中 ... 
- 如何用js获取日期(转载)
			本文介绍了js获取日期的方法,可以获取前天.昨天.今天.明天.后天. 代码: <html> <head> <meta http-equiv="Content-T ... 
- 基于node.js及express实现中间件,实现post、get
			首先,当然是有必要的环境,安装node,这个我就不多说了. 依赖模块: "express": "^4.13.4", "request": & ... 
- 使用TortoiseGit同步代码到github远程仓库
			1.clone github上的代码仓库的URL 可以用HTTPS,SSH, or Subversion 2.同步push 到远程仓库时 要用 SSH地址,同生成SSH private key ,在g ... 
- 【C++基础】重载,覆盖,隐藏
			函数签名的概念 函数签名主要包括1.函数名:2.参数列表(参数的个数.数据类型和顺序):但是注意,C++官方定义中函数签名不包括返回值!! 1.重载 函数重载是指在同一作用域内,可以有一组具有相同函数 ... 
- Poj_1011_Sticks(剪枝)
			一.Description 乔治拿来一组等长的木棒,将它们随机地砍断,使得每一节木棍的长度都不超过50个长度单位.然后他又想把这些木棍恢复到为裁截前的状态,但忘记了初始时有多少木棒以及木棒的初始长度. ... 
