ZR#955 折纸

解法:

可以发现折纸之后被折到上面的部分实际上是没有用的,因为他和下面对应位置一定是一样的,而影响答案的只有每个位置的颜色和最底层的坐标范围。因此,我们只需要考虑最底层即可,即我们可以把折纸等效为裁纸,每次去掉较小的那一部分。

用哈希维护每一列和每一行的极大回文子串,记录一下行与列的最大值相乘即可。

CODE:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath> using namespace std; #define LL long long
const int N = 2e6 + 50; char s[N],tt[N];
string p[N];
int HL[N],WL[N],m,n;
int HR[N],WR[N],t[N],f[N]; int manacher(int *p, char *ss, int Len) {
int len = 0; s[0] = '(';
for(int i = 1 ; i <= Len ; ++ i) {
s[++ len] = '#';
s[++ len] = ss[i];
}
s[++ len] = '#', s[++ len] = ')';
int mx = 0, id = 0;
for(int i = 1 ; i < len ; ++ i) {
if(i < mx) p[i] = min(mx - i, p[2 * id - i]);
else p[i] = 1;
while(s[i + p[i]] == s[i - p[i]]) ++ p[i];
if(i + p[i] > mx) mx = i + p[i], id = i;
}
return len;
} int main() {
scanf("%d%d",&n,&m);
for(int i = 1 ; i < n ; i++)
HL[i] = HR[i] = 1;
for(int i = 1 ; i < m ; i++)
WL[i] = WR[i] = 1;
for(int i = 1 ; i <= n ; i++)
cin >> p[i];
for(int i = 1 ; i <= n ; i++) {
int len = m;
for(int j = 1 ; j <= len ; j++)
tt[j] = p[i][j - 1];
int Len = manacher(t, tt, m) - 3;
int mx = 1;
for(int j = 3 ; j <= Len ; j += 2) {
if(j - t[j] + 1 <= mx) mx = j;
else WL[j >> 1] = 0;
}
int mn = Len + 2;
for(int j = Len ; j >= 3 ; j -= 2) {
if(j + t[j] - 1 >= mn) mn = j;
else WR[j >> 1] = 0;
}
}
LL ansW = 0;
int sum = 0;
WL[0] = 1, WR[m] = 1;
for(int i = 0 ; i <= m ; i++) sum += WR[i];
for(int i = 0 ; i <= m ; i++) {
if(WR[i]) -- sum;
if(WL[i]) ansW += sum;
}
swap(n, m);
for(int i = 1 ; i <= n ; i++) {
int len = m;
for(int j = 1 ; j <= len ; j++)
tt[j] = p[j][i - 1];
int Len = manacher(t, tt, m) - 3;
int mx = 1;
for(int j = 3 ; j <= Len ; j += 2) {
if(j - t[j] + 1 <= mx) mx = j;
else HL[j >> 1] = 0;
}
int mn = Len + 2;
for(int j = Len ; j >= 3 ; j -= 2) {
if(j + t[j] - 1 >= mn) mn = j;
else HR[j >> 1] = 0;
}
}
LL ansH = 0;
sum = 0;
HL[0] = 1, HR[m] = 1;
for(int i = 0 ; i <= m ; i++) sum += HR[i];
for(int i = 0 ; i <= m ; i++) {
if(HR[i]) -- sum;
if(HL[i]) ansH += sum;
}
printf("%lld\n", ansW * ansH);
//system("pause");
return 0;
}

ZR#955 折纸的更多相关文章

  1. CSS3写折纸

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  2. 折纸问题java实现

    /** * 折纸问题 这段代码写的太low了 本人水平有限 哎... 全是字符串了 * @param n * @return * @date 2016-10-7 * @author shaobn */ ...

  3. 【BZOJ】1074: [SCOI2007]折纸origami

    http://www.lydsy.com/JudgeOnline/problem.php?id=1074 题意:一开始有一个左上角是(0,100),右下角是(100,0)的纸片,现在可以沿有向直线折n ...

  4. 1074: [SCOI2007]折纸origami - BZOJ

    Description 桌上有一张边界平行于坐标轴的正方形纸片,左下角的坐标为(0,0),右上角的坐标为(100,100).接下来执行n条折纸命令.每条命令用两个不同点P1(x1,y1)和P2(x2, ...

  5. CSS3实现文字折纸效果

    CSS3实现文字折纸效果 效果图: 代码如下,复制即可使用: <!DOCTYPE html> <html> <head> <title></tit ...

  6. 1074: [SCOI2007]折纸origami

    Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 372  Solved: 229[Submit][Status][Discuss] Descriptio ...

  7. UVA 177 PaperFolding 折纸痕 (分形,递归)

    著名的折纸问题:给你一张很大的纸,对折以后再对折,再对折……每次对折都是从右往左折,因此在折了很多次以后,原先的大纸会变成一个窄窄的纸条.现在把这个纸条沿着折纸的痕迹打开,每次都只打开“一半”,即把每 ...

  8. [CSP-S模拟测试]:折纸(模拟)

    题目描述 小$s$很喜欢折纸.有一天,他得到了一条很长的纸带,他把它从左向右均匀划分为$N$个单位长度,并且在每份的边界处分别标上数字$0\sim n$.然后小$s$开始无聊的折纸,每次他都会选择一个 ...

  9. 嵊州D5T2 折纸 folding

    折纸 folding [问题描述] 在非常紧张的 NOIP 考试中,有人喜欢啃指甲,有人喜欢转铅笔,有人喜欢撕 纸条,……而小 x 喜欢迷折纸. 现有一个 W * H 的矩形纸张,监考老师想知道,小 ...

随机推荐

  1. Dapper 入门

    中文文档连接:https://www.w3cschool.cn/dapperorm/dapperorm-toj931f2.html 官网文档连接:https://dapper-tutorial.net ...

  2. 【原创】大叔经验分享(89)docker启动openjdk执行jmap报错

    docker启动openjdk后,可以查看进程 # docker exec -it XXX jps 10 XXX.jar 可见启动的java进程id一直为10,然后可以执行jvm命令,比如 # doc ...

  3. Docker多阶段构建实战(multi-stage builds)

    在编写Dockerfile构建docker镜像时,常遇到以下问题: RUN命令会让镜像新增layer,导致镜像变大,虽然通过&&连接多个命令能缓解此问题,但如果命令之间用到docker ...

  4. Python模拟登陆某网教师教育网

    本文转载自看雪论坛[作者]rdsnow 不得不说,最近的 Python 蛮火的,我也稍稍了解了下,并试着用 Python 爬取网站上的数据 不过有些数据是要登陆后才能获取的,我们每年都要到某教师教育网 ...

  5. python数据写入Excel表格

    from openpyxl import Workbook def main(): sheet_name = "表名1" row_count = 6 # 行数 info_resul ...

  6. 案例:selenium实现登录百度(如有验证码,需要手动输入)

    func.py https://www.cnblogs.com/andy9468/p/10899508.html baidu_login.py中(如有验证码,需要手动输入) # 导入webdriver ...

  7. pymysql 1064, 'You have an error in your SQL syntax; check the manual that corresponds to

    在python 连接mysql时,最近一直出现了 1064, 'You have an error in your SQL syntax; check the manual that correspo ...

  8. TCP/UDP Socket调试工具提供了TCP Server,TCP Client,UDP Server,UDP Client,UDP Group 五种Socket调试方案。

    一.TCP通信测试: 1)   创建TCP Server: 选中左方的TCP Server, 然后点击”创建”按钮,软件弹出监听端口输入框 输入监听端口后,即创建了一个在指定端口上进行监听的TCP S ...

  9. js 获取扫码枪信息

    ---- js 获取扫码枪不需要记录 lastCode 啊,只需要在时间超出范围的时候重置 lastTime 和 code 就行了.如果 码枪会输入回车,那就在 keyCode === 13 的时候使 ...

  10. TODO 疑问:java中的工厂类,在实际项目中如何运用

    正在读core of java,工厂类一直没搞懂.感觉和静态方法相类似,但是不知道是怎么运用在实际中. 20190711: 读了设计模式,里面给出的解读是这样的 Define an interface ...