#L2764. 「JOI 2013 Final」JOIOI 塔

    ID: 5594 传统题 1000ms 256MiB 尝试: 2 已通过: 1 难度: 10 上传者: 标签>贪心树结构次小生成树字符串匹配栈模拟双指针二分答案资源分配优化

「JOI 2013 Final」JOIOI 塔

题目描述

本题译自 JOI 2013 Final T4「JOIOIの塔」

JOIOI 塔是一种单人游戏。

这个游戏要用到一些写有 J, O, I 中任一文字的圆盘。这些圆盘的直径互不相同。游戏开始时,这些圆盘按照直径大的在下面的规则堆叠。你需要用这些圆盘做尽量多的迷你 JOIOI 塔。迷你 JOIOI 塔由 33 个圆盘构成,从直径较小的圆盘开始分别为 J, O, I 或分别为 I, O, I 。不过,每个圆盘最多只能使用一次。

任务

给出长为 NN 的字符串 SS ,表示直径从小到大的圆盘上的文字。请编写程序求出使用这些圆盘能够做出的迷你 JOIOI 塔个数的最大值。

输入格式

第一行为一个整数 NN ,表示字符串 SS 的长度。
第二行是一个字符串 SS

输出格式

输出一行一个整数:表示能够做出的迷你 JOIOI 塔数量的最大值。

样例 1

输入

6
JOIIOI

输出

2

解释
JOIIOI 分别含子串 JOI 和子串 IOI 各一个,故可以做出 22 个迷你 JOIOI 塔。

样例 2

输入

5
JOIOI

输出

1

解释
虽然 JOIOI 也分别含子串 JOI 和子串 IOI 各一个,但每个字符不能被使用两次或以上。

样例 3

输入

6
JOIOII

输出

2

解释
此样例对应题目描述中的例子。

样例 4

输入

15
JJOIIOOJOJIOIIO

输出

4

数据范围与提示

对于所有数据,1N1061 \leq N \leq 10^6

子任务 分值 NN \leq
1 10 1515
2 20 5050
3 30003000
4 50 10610^6

算法标签
贪心算法, 字符串匹配, 栈模拟, 双指针, 二分答案, 资源分配优化