题意:给出一个字符矩形,问找到一个最小的字符矩形,令它无限复制之后包含原来的矩形。

此题用KMP+枚举来做。

一维的字符串匹配问题可以用KMP来解决。但是二维的就很难下手。我们可以将二维问题转化为一维来做。

首先可以发现这个最小的字符矩形一定是在左上角的。

这样我们对每列枚举它的前缀的长度,如果是能形成重复子串,就记录一下该长度。为了能形成矩形,统计出现R次的最短长度L(一定会有出现R次的长度,最坏的情况下这个长度是C)。

比如:

ABCABCABC(长度为3和9的前缀可以形成重复子串)

ABABABABA(长度为2、4和9的前缀可以形成重复子串)

只有长度为9的前缀在每行都出现了,所以最短长度L=9。

这样我们就得到了最小重复矩形的列数目。

然后将每行的字符串看作一个字符进行KMP,求next数组。它的周期就是R-next[R]。

最终答案就是L*(R-next[R])。

 #include<iostream>
 #include<cstring>
 #include<cstdio>
 using namespace std;
 ];
 ][];
 ];
 int r,c;
 void getFail()
 {
     ; i<r; ++i)
     {
         int j=next[i];
         while(j&&strcmp(str[i],str[j])) j=next[j];
         next[i+]=(!strcmp(str[i],str[j]))?j+:;
     }
 }
 ];
 bool match(char *a,char *b)
 {
     int la=strlen(a);
     ,j=; i<c; ++i,++j)
     {
         ;
         if(a[j]!=b[i]) return false;
     }
     return true;
 }
 int main()
 {
     while(scanf("%d%d",&r,&c)!=EOF)
     {
         ; i<r; ++i)
             scanf("%s",str[i]);
         memset(cnt,,sizeof(cnt));
         ; i<r; ++i)
         {
             ; j<c; ++j)
             {
                 word[j]=str[i][j];
                 word[j+]=;
                 if(match(word,str[i]))
                     cnt[j]++;
             }
         }
         getFail();
         int x=c,y=r-next[r];
         ; i<c; ++i)
             if(cnt[i]==r)
             {
                 x=i+;
                 break;
             }
         printf("%d\n",x*y);
     }
     ;
 }

POJ 2185 - Milking Grid (二维KMP)的更多相关文章

  1. POJ 2185 Milking Grid [二维KMP next数组]

    传送门 直接转田神的了: Milking Grid Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 6665   Accept ...

  2. Match:Milking Grid(二维KMP算法)(POJ 2185)

    奶牛矩阵 题目大意:给定一个矩阵,要你找到一个最小的矩阵,这个矩阵的无限扩充的矩阵包含着原来的矩阵 思路:乍一看这一题确实很那做,因为我们不知道最小矩阵的位置,但是仔细一想,如果我们能把矩阵都放在左上 ...

  3. POJ 2185 Milking Grid KMP循环节周期

    题目来源:id=2185" target="_blank">POJ 2185 Milking Grid 题意:至少要多少大的子矩阵 能够覆盖全图 比如例子 能够用一 ...

  4. 题解报告:poj 2185 Milking Grid(二维kmp)

    Description Every morning when they are milked, the Farmer John's cows form a rectangular grid that ...

  5. [poj 2185] Milking Grid 解题报告(KMP+最小循环节)

    题目链接:http://poj.org/problem?id=2185 题目: Description Every morning when they are milked, the Farmer J ...

  6. POJ 2185 Milking Grid(KMP)

    Milking Grid Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 4738   Accepted: 1978 Desc ...

  7. 【KMP】POJ 2185 Milking Grid -- Next函数的应用

    题目链接:http://poj.org/problem?id=2185 题目大意:求一个二维的字符串矩阵的最小覆盖子矩阵,即这个最小覆盖子矩阵在二维空间上不断翻倍后能覆盖原始矩阵. 题目分析:next ...

  8. POJ 2185 Milking Grid KMP(矩阵循环节)

                                                            Milking Grid Time Limit: 3000MS   Memory Lim ...

  9. POJ 2185 Milking Grid [KMP]

    Milking Grid Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 8226   Accepted: 3549 Desc ...

随机推荐

  1. ios 开发 收起键盘的小技巧

    在UIViewController中收起键盘,除了调用相应控件的resignFirstResponder方法外,还有另外三种方法: 1.重载UIViewController中的touchesBegin ...

  2. 鼠标经过导航中li时,一个彩色模块跟着鼠标移动

    1.鼠标经过导航中li时,一个活动的li跟随鼠标移动,最终移动到鼠标的停留的位置.(如需鼠标离开后让活动的li回到初始位置,则用jq hover事件,当鼠标离开时,给活动的li设置left是0) 2. ...

  3. robotframework笔记9

    列表和字典 通过专用关键字创建了列表和字典.我们将在这里看到创建的两个例子 ︰ 选择 *** Settings *** Library BuiltIn Library Collections *** ...

  4. 《Java程序设计》第九周学习总结

    20145224 <Java程序设计>第九周学习总结 第十六章 整合数据库 JDBC入门 ·数据库本身是个独立运行的应用程序 ·撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的 ...

  5. MVC之URL路由

    注册路由规则集合 一个 Web 应用具有一个全局的路由表,该路由表通过 System. Web.Routing.RouteTable的静态只读属性 Routes 表示,该属性返回一个类型为 Syste ...

  6. 实例化Layout中的布局文件(xml)

    什么是LayoutInflater This class is used to instantiate layout XML file into its corresponding View obje ...

  7. BZOJ3058 四叶草魔杖

    Poetize11的T3 蒟蒻非常欢脱的写完了费用流,发现...边的cost竟然只算一次!!! 然后就跪了... Orz题解:"类型:Floyd传递闭包+最小生成树+状态压缩动态规划首先Fl ...

  8. linux shell 单引号 双引号 反引号的区别

    一.单引号和双引号 首先, 单引号和双引号,都是为了解决中间有空格的问题. 因为空格在linux中时作为一个很典型的分隔符,比如 string1=this is a string,这样执行就会报错.为 ...

  9. java面向对象编程--第九章 多态和抽象

    9.1多态 在生物学中,是指一个生物或物种可以有多种不同的形式或阶段: 在OOP中,多态是指一个对象有多种形式的能力. 多态可以说是面向对象编程的精髓所在.java中之所以引入多态的概念,原因之一是它 ...

  10. 从问题域出发认识Hadoop生态系统

    近些年来Hadoop生态系统发展迅猛,它本身包含的软件越来越多,同时带动了周边系统的繁荣发展.尤其是在分布式计算这一领域,系统繁多纷杂,时不时冒出一个系统,号称自己比MapReduce或者Hive高效 ...