CodeForces 52B Right Triangles 矩阵上的计数

题目链接:点击打开链接

题意:

问有多少个与矩阵边平行的直角三角形。且三角形的3个顶点都是*

对于 L形 或者_| 形的三角形。我们仅仅须要知道在_ 上方有多少个*就可以,下底边则任取2个

所以用l[i]表示 第i列的*的个数

然后扫完一行,再把这行的*更新到 l[] 里

从上到下扫一遍得到全部 L _| 的三角形

再从下到上扫一遍 得到 ~| 和 |~ 的。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <math.h>
#include <queue>
#include <functional>
#include <iostream>
using namespace std;
#define ll long long
#define N 1005
ll l[N];
ll n, m;
vector<ll> x;
char s[N][N];
int main(){
    ll i, j;
    while(cin>>n>>m){
        for(i = 1; i <= n; i++)
            scanf("%s", s[i]+1);
        ll ans = 0;
        memset(l, 0, sizeof l);
        for(i = 1; i <= n; i++)
        {
            ll pre = 0;
            x.clear();
            for(j = 1; j <= m; j++)
            {
                if(s[i][j] == '*' && l[j])
                    x.push_back(l[j]);
                if(s[i][j] == '*')
                    pre++;
            }
            for(j = 0; j < x.size(); j++)
                ans += x[j] * (pre - 1);
        //    cout<<ans<<endl;
            for(j = 1; j <= m; j++)
                if(s[i][j] == '*')l[j]++;
        }
        memset(l, 0, sizeof l);
        for(i = n; i ; i--)
        {
            ll pre = 0;
            x.clear();
            for(j = 1; j <= m; j++)
            {
                if(s[i][j] == '*' && l[j])
                    x.push_back(l[j]);
                if(s[i][j] == '*')
                    pre++;
            }
            for(j = 0; j < x.size(); j++)
                ans += x[j] * (pre - 1);
         //   for(j = 0; j < x.size(); j++)cout<<x[j]<<" "; puts("");            cout<<"    "<<ans<<endl;
            for(j = 1; j <= m; j++)
                if(s[i][j] == '*')l[j]++;
        }
        cout<<ans<<endl;
    }
    return 0;
}
时间: 2024-10-21 01:34:07

CodeForces 52B Right Triangles 矩阵上的计数的相关文章

Codeforces Round #258 D Count Good Substrings --计数

题意:由a和b构成的字符串,如果压缩后变成回文串就是Good字符串.问一个字符串有几个长度为偶数和奇数的Good字串. 分析:可知,因为只有a,b两个字母,所以压缩后肯定为..ababab..这种形式,所以是good substrings,那么首尾字符肯定相同,于是就好搞了. 用:odd[0],odd[1]分别记录奇数位置上出现的a和b的个数,even[0],even[1]分别记录偶数位置上的a,b个数. 那么到一个奇数点时,奇数长度的子串个数应该加上奇数位置的该字符的个数,偶数长度的应该加上偶

矩阵快速幂——将运算推广到矩阵上HDU 1575

/* 本题的思路比较简单,就是将递推公式写出来,然后表达成为一个矩阵的形式 最后通过计算就可以得到一个符合题目要求的矩阵, 然后就是将矩阵上面所有的对角线元素相加 得到的结果即为所求的目标 */ #include<cstdio>  #include<cstring>  using namespace std;  const int maxn = 15;  #define mod 9973  int res[maxn][maxn];  int n;  void mul(int a[]

OpenCV在矩阵上的卷积

转载请注明出处!!!http://blog.csdn.net/zhonghuan1992 OpenCV在矩阵上的卷积 在openCV官网上说是戴面具,事实上就是又一次计算一下矩阵中的每个value,那么怎么计算呢,依据该像素点的周围信息,用一个加权的公式来进行计算.那么如今就要看,周围的信息是怎样被加权的.让我们想一下这种方式,请看以下的公式: 上面的公式就是根据当前像素点的值和四个邻居的值,更新一下.相当于原来矩阵每一块3*3的小矩阵和M进行想乘一样. 在程序中,我们对该公式进行编程的话,会是

HDU 4975 A simple Gaussian elimination problem. 网络流+矩阵上的dp

随机输出保平安啊 和hdu4888一个意思,先跑个网络流然后dp判可行. ==n^3的dp过不了,所以把n改成200. ==因为出题人没有把多解的情况放在200*200以外的矩阵. #include <cstdio> #include <cstring> #include <vector> #include <queue> #include <algorithm> using namespace std; const int MAX_N = 12

CodeForces 185A. Plant(矩阵快速幂)

题目链接:http://codeforces.com/problemset/problem/185/A Dwarfs have planted a very interesting plant, which is a triangle directed "upwards". This plant has an amusing feature. After one year a triangle plant directed "upwards" divides int

codeforces 277.5 div2 F:组合计数类dp

题目大意: 求一个 n*n的 (0,1)矩阵,每行每列都只有两个1 的方案数 且该矩阵的前m行已知 分析: 这个题跟牡丹江区域赛的D题有些类似,都是有关矩阵的行列的覆盖问题 牡丹江D是求概率,这个题是方案数,也比较相似.. 这种题中,因为只要求方案数..我们只要关注几行几列有几个1,而不必要关注具体的位置 题解: 行列都需要处理,因此考虑记录列的状态,然后一行一行的转移 最暴力的方程: dp[i][j][k][t] 表示已经确定了 i 行 有 j列已经有两个1,有k列只有一个1,有t列一个1也没

Codeforces 451E Devu and Flowers(组合计数)

题目地址 在WFU(不是大学简称)第二次比赛中做到了这道题.高中阶段参加过数竞的同学手算这样的题简直不能更轻松,只是套一个容斥原理公式就可以.而其实这个过程放到编程语言中来实现也没有那么的复杂,不过为了让计算机在限定的时间内完成计算需要进行一些对计算上的优化.模MOD的情况下计算组合数nCr只需要求出分子再乘以分母的逆元,考虑到模的是1e9+7本身就是一个质数,根据费马小定理a^(MOD-2)即是a在模MOD意义下的逆元.求逆元的时候为了节约计算时间可以采用快速幂.计算过程就是容斥原理,就没有什

bzoj 2406: 矩阵 上下界网络流判定

2406: 矩阵 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 138  Solved: 46[Submit][Status][Discuss] Description Input 第一行两个数n.m,表示矩阵的大小. 接下来n行,每行m列,描述矩阵A. 最后一行两个数L,R. Output 第一行,输出最小的答案: Sample Input 2 2 0 1 2 1 0 1 Sample Output 1 HINT 对于100%的数据满足N,M<

CodeForces - 13D :Triangles(向量法:问多少个蓝点三角形内部无红点)

Little Petya likes to draw. He drew N red and M blue points on the plane in such a way that no three points lie on the same line. Now he wonders what is the number of distinct triangles with vertices in red points which do not contain any blue point