[Usaco2015 OPEN] Palindromic Paths
[题目链接]
https://www.lydsy.com/JudgeOnline/problem.php?id=4098
[算法]
显然 , 回文路径中第i个字母的位置(x , y)必然满足 : x + y - 1 = i
用f[i][j][k]表示现在在第i步 , 左上的横坐标为j , 右下的横坐标为k , 有多少种方案使得两边路径上的字母序列相同 , DP即可
时间复杂度 : O(N ^ 3)
滚动数组 , 将空间复杂度优化为O(N ^ 2)
[代码]
#include<bits/stdc++.h>
using namespace std;
#define MAXN 510
const int P = 1e9 + ; int n;
int f[][MAXN][MAXN];
char mp[MAXN][MAXN]; inline void update(int &x , int y)
{
x += y;
x %= P;
}
inline bool valid(int x , int y)
{
return x >= && x <= n && y >= && y <= n;
} int main()
{ scanf("%d",&n);
for (int i = ; i <= n; i++) scanf("%s",mp[i] + );
if (mp[][] == mp[n][n])
{
f[][][n] = ;
} else
{
printf("0\n");
return ;
}
for (int i = ; i <= n; i++)
{
int now = i & , nxt = now ^ ;
memset(f[nxt] , , sizeof(f[nxt]));
for (int x = ; x <= n; x++)
{
for (int y = ; y <= n; y++)
{
int t1 = i + - x , t2 = * n - y + - i;
if (!valid(x , t1) || !valid(y , t2)) continue;
if (!f[now][x][y]) continue;
if (valid(x , t1 + ))
{
if (valid(y , t2 - ) && mp[x][t1 + ] == mp[y][t2 - ])
update(f[nxt][x][y] , f[now][x][y]);
if (valid(y - , t2) && mp[x][t1 + ] == mp[y - ][t2])
update(f[nxt][x][y - ] , f[now][x][y]);
}
if (valid(x + , t1))
{
if (valid(y , t2 - ) && mp[x + ][t1] == mp[y][t2 - ])
update(f[nxt][x + ][y] , f[now][x][y]);
if (valid(y - , t2) && mp[x + ][t1] == mp[y - ][t2])
update(f[nxt][x + ][y - ] , f[now][x][y]);
}
}
}
}
int ans = ;
for (int i = ; i <= n; i++) update(ans , f[n & ][i][i]);
printf("%d\n" , ans); return ; }
[Usaco2015 OPEN] Palindromic Paths的更多相关文章
- [bzoj4098] [Usaco2015 Open]Palindromic Paths
DP.. f[i][j][k]表示左上结束节点是第i条副对角线上的第j个点,右下结束节点是第n*2-i条副对角线上的第k个点,构成回文的方案数. i那维滚动一下.时间复杂度O(n^3)空间复杂度O(n ...
- [USACO15OPEN]回文的路径Palindromic Paths
[USACO15OPEN]回文的路径Palindromic Paths 题目描述 Farmer John's farm is in the shape of an N \times NN×N grid ...
- TOJ 5020: Palindromic Paths
5020: Palindromic Paths Time Limit(Common/Java):10000MS/30000MS Memory Limit:65536KByteTotal Su ...
- 题解 P3126 【[USACO15OPEN]回文的路径Palindromic Paths】
P3126 [USACO15OPEN]回文的路径Palindromic Paths 看到这题题解不多,蒟蒻便想更加通俗易懂地分享一点自己的心得,欢迎大佬批评指正^_^ 像这种棋盘形的两边同时做的dp还 ...
- Educational Codeforces Round 89 (Rated for Div. 2) C Palindromic Paths
题目链接:Palindromic Paths 题意: 给你一个n行m列的矩阵,这个矩阵被0或者1所填充,你需要从点(1,1)走到点(n,m).这个时候会有很多路径,每一条路径对应一个01串,你可以改变 ...
- [USACO15OPEN]回文的路径Palindromic Paths 2.0版
题目描述 农夫FJ的农场是一个N*N的正方形矩阵(2\le N\le 5002≤N≤500),每一块用一个字母作标记.比如说: ABCD BXZX CDXB WCBA 某一天,FJ从农场的左上角走到右 ...
- Palindromic Paths(DP)
描述 Given an N×N grid of fields (1≤N≤500), each labeled with a letter in the alphabet. For example: A ...
- Codeforces 1205C Palindromic Paths (交互题、DP)
题目链接 http://codeforces.com/contest/1205/problem/C 题解 菜鸡永远做着变巨的梦 然而依然连div1BC题都不会做 要是那天去打cf怕是又要1题滚粗了.. ...
- CF1205C Palindromic Paths
题目链接 问题分析 首先可以想到,坐标和为奇数的位置可以被唯一确定.同样的,如果假定\((1,2)\)是\(0\),那么坐标和为偶数的位置也可以被唯一确定.这样总共使用了\(n^2-3\)次询问. 那 ...
随机推荐
- Spring Boot Reactive Streams
1 响应式编程规范 目标:provide a standard for asynchronous stream processing with non-blocking backpressure ht ...
- 七牛云赵之健:多维度融合赋能视频 AI 的实践
6 月 30 日下午,赵之健在七牛架构师实践日第二十九期进行了<多维度融合赋能视频 AI 的实践>为题的实战分享. 作者简介: 赵之健,七牛人工智能实验室资深算法工程师, 七 ...
- BZOJ2662[BeiJing wc2012]冻结【SPFA】
“我要成为魔法少女!” “那么,以灵魂为代价,你希望得到什么?” “我要将有关魔法和奇迹的一切,封印于卡片之中„„” 在这个愿望被实现以后的世界里,人们享受着魔法卡片(SpellCard ...
- PHP目录文件遍历
<meta charset="utf-8"><?php //遍历文件中的所有文件名称 foreach(glob("phpmyadmin/*") ...
- excludepathpatterns 无效
踩坑了,调了好久才调出来. 原因: 访问的API /XXX 已经转换为 /error 了. 把“/error” 也加入 excludepathpatterns 里面即可.
- python之-微信开发学习
微信公众平台技术文档https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1445241432# 注意,最好以python3 运行,中文 ...
- datasnap使用ipv6
有些人说DATASNAP不支持IPv6,只支持IPv4. 这是不正确的. DATASNAP默认是使用IPv4在ipv6 环境下 怎样用datasnap?Params.Values['Communica ...
- centos mysql错误信息处理
mysql_secure_installation 提示错误:Enter current password for root (enter for none):ERROR 1045 (28000): ...
- 3.将maven项目jar纳入maven仓库,Mave项目依赖另外一个Maven项目的案例
1 若想让maven项目依赖另外一个maven项目.被依赖的项目要在maven仓库中有对应的jar包,所以要对依赖的项目运行mvninstall命令. 2 新建第二个项目模块HelloFrien ...
- 给工作赋予的新意义——Leo鉴书78
现代社会学三大奠基人有两位名字里有"马克思",他们都是德国人.当中一位就是写<资本论>的卡尔•马克思,另一位就是<新教伦理与资本主义精神>的作者马克思•韦伯 ...