小红的数组清空
时间限制:C/C++/Rust/Pascal 1秒,其他语言2秒
空间限制:C/C++/Rust/Pascal 256 M,其他语言512 M
64bit IO Format: %lld

题目描述

小红拿到了一个数组,她准备用尽可能少的代价将该数组全部清空。
小红有两种操作:
1. 直接删除一个元素x,花费代价为 1。
2. 若上一个删除的元素为x,那么直接删除一个元素x+1,花费代价为 0。该操作仅当x+1在数组中存在时才可进行。

请你求出小红清空整个数组的最小代价。

输入描述:

第一行输入一个正整数n,代表数组的大小。
第二行输入n个正整数a_i,用空格隔开。代表数组的元素。
1\leq n \leq 10^5
1\leq a_i \leq 10^9

输出描述:

输出一个正整数,代表小红清空整个数组的最小代价。
示例1

输入

复制
3
1 2 3

输出

复制
1

说明

第一次操作,删除 1,代价为 1。
第二次操作,删除 2,代价为 0。
第三次操作,删除 3,代价为 0。
示例2

输入

复制
5
2 1 6 5 7

输出

复制
2
示例3

输入

复制
2
1 1

输出

复制
2