#471. 礼品摆放
礼品摆放
题目描述
小码君过生日的时候会收到很多礼物,他会把礼物摆放在卧室的展示架上。但是展示架容量有限,只能放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。