// 关键思想
对于顶点(i,j)能构成树的数量 == min(顶点(i + 1,j - 1)构成树的数量,顶点(i + 1,j)构成树的数量,顶点(i + 1,j + 1)构成树的数量) + 1
#include<iostream>
#include<cstring>
using namespace std;const int N = 510;
int d[N][N];int main()
{int t;cin >> t;while(t --){int n,m;cin >> n >> m;memset(d,0,sizeof d);for(int i = 1; i <= n; i ++)for(int j = 1; j <= m; j ++){char c;cin >> c;d[i][j] = (c == '*');}long long ans = 0;for(int i = n; i >= 1; i --)for(int j = 1; j <= m; j ++){if(d[i][j]) d[i][j] = min( min(d[i + 1][j - 1],d[i + 1][j]),d[i + 1][j + 1]) + 1;ans += d[i][j];}cout << ans << endl;}
}
本文发布于:2024-02-02 00:59:02,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170681178540375.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |