#488. 礼品摆放

礼品摆放

题目描述

小码君过生日的时候会收到很多礼物,他会把礼物摆放在卧室的展示架上。但是展示架容量有限,只能放M个礼物。每次小码君收到一个礼物时,先看一下架子上是否已经有相同的,如果有就不会摆上去,否则,就找一个位置摆放,如果架子上已经摆满了礼物,那他就会把最早放在架子上的礼物拿走,再放新的。每次摆放一个礼物,小码君的高兴程度就会增加1。问:小码君的高兴程度最终是多少。

输入格式

共 2 行。每行中两个数之间用一个空格隔开。

第一行为两个正整数 M,N,代表展示架的容量和收到的礼物数目。

第二行为 N 个非负整数,按照收到的顺序,每个数(大小不超过 1000)代表一个礼物。两个礼物相同,当且仅当它们对应的非负整数相同。

输出格式

一个整数,表示小码君最终的高兴程度

样例

输入:

3 7

1 2 1 5 4 4 1

输出:

5

数据范围与提示

过程如下:每行表示收到一个礼物,冒号前为处理完展示架的状况:

空:展示架初始状态为空。

1. 1:摆放礼物1。

2. 1 2:摆放礼物2。

3. 1 2:礼物1已经在展示架上。

4. 1 2 5:摆放礼物5。

5. 2 5 4:拿走礼物1,摆放礼物4。

6. 2 5 4:礼物4已经在展示架上。

7. 5 4 1:拿走礼物2,摆放礼物1。

共摆放5次礼物

【测试数据范围】

对于10%的数据有 M = 1,N ≤ 5。

对于100%的数据有 0 < M ≤ 100,0 < N ≤ 1000。