hdu6052

题意

给出一个 \(n * m\) 的网格矩阵,每个格子都有颜色,随机选出一个子矩阵,问颜色种数的期望。

分析

那么我们可以去算所有矩阵的颜色种数之和,也就是每种颜色出现过的矩阵的个数之和,除以子矩阵的个数就是答案。

为了避免重复,我们要规定哪些矩阵属于某个格子。如果一些格子颜色为 \(1\) ,矩阵 \(A\) 中所有颜色为 \(1\) 的格子中,按从左到右,从上到下的顺序,一定有一个格子 \(a\) 在前,我们把这个矩阵 \(A\) 叫做(归为) \(a\) 的子矩阵。(某个子矩阵属于那个格子,是针对那个格子的颜色以及子矩阵中具有相同颜色的格子而言)

计算每种颜色在多少个子矩阵中出现过,直接去枚举矩阵,枚举到某一个格子时,它的下边界一定是 \(n\) ,上边界先设为当前行,在没有改变上边界的情况下,右边界为 \(m\) ,向左寻找,如果不存在相同颜色的格子,那么左边界为 \(1\) ,计算包含这个格子的矩阵数量(边界的意思是边界里的格子都能用)。

然后上边界不断上移,更新左右边界的值。

code

#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
const int MAXN = 1e2 + 10;
int n, m;
int c[MAXN][MAXN];
ll fun(int x, int y) {
ll sum = 0;
int L = 1, R = m;
for(int i = x; i >= 1; i--) {
if(i != x && c[i][y] == c[x][y]) break;
int l = 1, r = m;
for(int j = y - 1; j >= 1; j--) {
if(c[i][j] == c[x][y]) {
l = j + 1;
break;
}
}
if(i != x) {
for(int j = y + 1; j <= R; j++) {
if(c[i][j] == c[x][y]) {
r = j - 1;
break;
}
}
}
L = max(L, l);
R = min(R, r);
sum += 1LL * (y - L + 1) * (R - y + 1) * (n - x + 1);
}
return sum;
}
int main() {
int T;
scanf("%d", &T);
while(T--) {
scanf("%d%d", &n, &m);
for(int i = 1; i <= n; i++) {
for(int j = 1; j <= m; j++) {
scanf("%d", &c[i][j]);
}
}
ll sum = 0, num = 0;
for(int i = 1; i <= n; i++) {
for(int j = 1; j <= m; j++) {
sum += 1LL * (n - i + 1) * (m - j + 1);
num += fun(i, j);
}
}
printf("%.9f\n", 1.0 * num / sum);
}
return 0;
}

hdu6052的更多相关文章

随机推荐

  1. 【题解】SCOI2009围豆豆

    很久之前就很想做的一道题,一直思考到今天才下定决心看题解.这道题中,很关键的一点就在于:如何判断一个点是否在一个多边形内?其实如果计算几何基本功扎实的话,应该是可以很快给出答案的(可惜我完全不行):由 ...

  2. [CF632A]Grandma Laura and Apples

    题目大意:有$n$个顾客买苹果,每个买一半的苹果,有时会送半个苹果.最后卖光了,问卖了多少钱 题解:倒退过来,可以把半个苹果当做一份来算,这样不会有小数 卡点:无 C++ Code: #include ...

  3. 洛谷 P2414 [NOI2011]阿狸的打字机 解题报告

    P2414 [NOI2011]阿狸的打字机 题目背景 阿狸喜欢收藏各种稀奇古怪的东西,最近他淘到一台老式的打字机. 题目描述 打字机上只有28个按键,分别印有26个小写英文字母和'B'.'P'两个字母 ...

  4. Angular 监听路由变化

    var app = angular.module('Mywind',['ui.router']) //Angular 监听路由变化 function run($ionicPlatform, $loca ...

  5. 深入理解Java虚拟机—内存管理机制

    前面说过了类的加载机制,里面讲到了类的初始化中时用到了一部分内存管理的知识,这里让我们来看下Java虚拟机是如何管理内存的. 先让我们来看张图 有些文章中对线程隔离区还称之为线程独占区,其实是一个意思 ...

  6. System l类arraycopy的用法

    package org.springframework; /** * @author 秦林森 */ public class Test { public static void main(String ...

  7. bzoj 3771 Triple FFT 生成函数+容斥

    Triple Time Limit: 20 Sec  Memory Limit: 64 MBSubmit: 847  Solved: 482[Submit][Status][Discuss] Desc ...

  8. loj6087 毒瘤题

    传送门:https://loj.ac/problem/6087 [题解] 这垃圾题目卡空间啊... k=1相信大家都会,把所有数异或起来就是答案了. 考虑k=2,把所有数异或起来得到两个答案数的异或值 ...

  9. [BZOJ1025] [SCOI2009]游戏 解题报告

    Description windy学会了一种游戏.对于1到N这N个数字,都有唯一且不同的1到N的数字与之对应.最开始windy把数字按顺序1,2,3,……,N写一排在纸上.然后再在这一排下面写上它们对 ...

  10. python 学习笔记 aiohttp

    asyncio可以实现单进程并发IO操作,如果仅用在客户端,发挥的威力并不大,如果把asyncio用在服务器端,由于http链接就是IO操作, 因此可以用单线程+coroutine实现多客户的高并发支 ...