Logo HelloWorld信息学奥赛题库

少儿编程

时间限制:1 s 空间限制:256 MB

#3566. 「JOI 2014 Final」JOI 徽章

统计

题目描述

译自 JOI 2014 Final T1「JOI 紋章

日本信息学奥赛委员会为了应援将要去台湾参加 IOI 的选手们,打算制作一面新的 JOI 旗帜。JOI 旗帜为由 $ M $ 行 $ N $ 列的 $ M\times N $ 个正方形组成的图形,每个正方形里写有 J,O,I 中任一字母。

4e1fb24a3b910a7ec7aeeea54107aa41.png

日本信息学奥赛委员会还决定制作 JOI 徽章 。JOI 徽章为由 $ 2 $ 行 $ 2 $ 列的 $ 4 $ 个正方形组成的图形,每个正方形里写有 J,O,I 中任一字母。

1abe2afec333ee4b1.png

JOI 旗帜中所含 JOI 徽章的个数的意思是,与 JOI 徽章相同(不允许翻转或旋转)的 JOI 旗帜中的 $ 2\times 2 $ 区域的个数。

现在日本信息学奥赛委员会拥有一张旧的 JOI 旗帜和一张白纸。这张白纸的大小和一个构成 JOI 旗的正方形的大小相同。可以在这张白纸上写上 J,O,I 中任一字母。日本信息学奥赛委员会将进行以下任意一种操作来制作新的 JOI 旗帜。

  • 不进行任何操作,直接把旧的旗帜当新的用。不使用白纸。
  • 在白纸上写下一个字母,将白纸覆盖在旧的 JOI 旗帜的任意一个正方形上(也就是变更旧的 JOI 旗帜的一个正方形的字母)。

日本信息学奥赛委员会想让新的 JOI 旗帜所含的 JOI 徽章的数量尽可能多。请求出新的 JOI 旗帜所含的 JOI 徽章的个数的最大值。

任务

给出旧的 JOI 旗帜和 JOI 徽章的情况,请求出新的 JOI 旗帜所含的 JOI 徽章的个数的最大值。

输入格式

输入标准如下:

  • 第一行为两个以空格分开的整数 $ M,N $ 。表示旧的 JOI 旗帜是由 $ M $ 行 $ N $ 列的 $ M×N $ 个正方形组成的图形。
  • 接下来的 $ M $ 行,每行为含有 $ N $ 个字符的字符串。每个字符为 J,O,I 中的一个。这 $ M $ 行中的第 $ i(1 \leq i \leq M) $ 行中从左数第 $ j(1 \leq j \leq N) $ 个字符表示旧的 JOI 旗帜上的第 $ i $ 行第 $ j $ 列的正方形中所写的字符。
  • 接下来的 $ 2 $ 行,每行为含有 $ 2 $ 个字符的字符串。每个字符为 J,O,I 中的一个。这 $ 2 $ 行中的第 $ i(1 \leq i \leq 2) $ 行中从左数第 $ j(1 \leq j \leq 2) $ 个字符表示 JOI 徽章上的第 $ i $ 行第 $ j $ 列的正方形中所写的字符。

输出格式

输出一行一个整数:表示新的 JOI 旗帜所含的 JOI 徽章的个数的最大值。

样例 1

input

3 5
JOIJO
IJOOO
IIJIJ
JO
IJ

output

3

旧的 JOI 旗帜和 JOI 徽章和题目描述中的例子一样。从上面起第 $ 2 $ 行中,从左起第 $ 4 $ 列的正方形中的字符用白纸覆盖从而变为 'J' 。

32905b8b3d90b3ddc.png

像这样变化后的 JOI 旗帜含 $ 3 $ 个 JOI 徽章。

472c0134893a30488.png

不存在能够包含 $ 4 $ 个 JOI 徽章的新的 JOI 旗帜。所以新的 JOI 旗帜所含的 JOI 徽章的个数的最大值为 $ 3 $ 。

样例 2

input

2 6
JOJOJO
OJOJOJ
OJ
JO

output

2

请注意:存在不使用白纸而能达到最大值的情况。

样例 3

input

2 2
JI
IJ
JJ
JJ

output

0

在输入样例 $3$ 的情况下,对于任何可能的新的 JOI 旗帜,都不可能含有 $ 1 $ 个 JOI 徽章。

数据范围与提示

对于 $ 30\% $ 的分值:

  • $ M \leq 50 $
  • $ N \leq 50 $

对于 $ 100\% $ 的数据,满足以下条件。

  • $ 2 \leq M \leq 1000 $
  • $ 2 \leq N \leq 1000 $