Codeforces 912D Fishs ( 贪心 && 概率期望 && 优先队列 )
题意 : 给出一个 N * M 的网格,然后给你 K 条鱼给你放置,现有规格为 r * r 的渔网,问你如果渔网随意放置去捕捞小鱼的情况下,捕到的最大期望值是多少?
分析 :
有一个很直观的想法就是如果将鱼放在越靠近中间的位置,其被捕捞的可能性越大
事实也的确如此,鱼的位置越靠近边缘则能覆盖到它的渔网安放位置就越少
那么这就有了一个贪心的算法
将第一条鱼放在最中间的位置算出被捕捉的概率
被捕捉的概率 = 能覆盖到当前小鱼位置的渔网个数 / 整个网格的全部安放渔网的方法数
然后从中间这个点开始向四周扩散,然后再找出概率最大的来进行扩张
因为概率越大说明其位置越靠近中间,所以首选概率最大的点进行扩张
这很像 BFS 的过程,所以我们可以使用一个优先队列来维护扩散出来的最大概率
然后选出前 K 个即可
对于每一个点能被多少个渔网放置方法覆盖,有个简便的方法
我们先分别算出横纵上的每一个点被覆盖的方法数即 (1~N, 1) 和 (1, 1~M)
然后对于中间的某个点,只要将刚刚算出来的结果进行相乘即可例如 (N, M) = (N, 1) * (1, M)
#include<bits/stdc++.h> #define LL long long using namespace std; ; , -, , }; , , -, }; struct NODE{ double P; int row, col; NODE(){}; NODE(int r, int c, double p):row(r),col(c),P(p){}; bool operator < (const NODE &rhs) const{ return this->P < rhs.P; }; }; set<pair<int, int> > s;///由于N*M太大了,所以用set进行判重 priority_queue<NODE> que; int R[maxn], C[maxn]; int n, m, r, k; bool bound(int row, int col)///判断是否越界,越界返回 true { || col< || row>n || col>m); } int add[maxn]; inline void Calculate_R_Array(int len, int r)///计算纵轴上每个点被覆盖的方案数 { ; i<=len-r+; i++) add[i]++, add[i+r]--; ; ; i<=len; i++) sum += add[i], R[i] = sum; } inline void Calculate_C_Array(int len, int r)///计算横轴 { ; i<=len-r+; i++) add[i]++, add[i+r]--; ; ; i<=len; i++) sum += add[i], C[i] = sum; } int main(void) { while(~scanf("%d %d %d %d", &n, &m, &r, &k)){ s.clear(); while(!que.empty()) que.pop(); LL tot = (LL)(n-r+)*(LL)(m-r+);///注意使用 long long 存储 memset(add, , sizeof(add)); Calculate_R_Array(n, r); memset(add, , sizeof(add)); Calculate_C_Array(m, r); s.insert(make_pair(n/+, m/+)); que.push(NODE(n/+, m/+, (+]*R[n/+])/(double)tot)); ; while(k--){ NODE T = que.top(); que.pop(); ans += T.P; ; i<; i++){///向四个点扩散 int newr = T.row + dr[i]; int newc = T.col + dc[i]; if(bound(newr, newc)) continue; if(!s.count(make_pair(newr, newc))){ s.insert(make_pair(newr, newc)); que.push(NODE(newr, newc, (double)(C[newc]*R[newr])/(double)tot)); } } } printf("%.9f\n", ans); } ; }
Codeforces 912D Fishs ( 贪心 && 概率期望 && 优先队列 )的更多相关文章
- Codeforces 912D Fishes (概率&期望,优先队列的应用)
题目链接 Fishes 题意 在一个$n*m$的矩阵中,随机选择一个$r * r$的区域覆盖. 一开始我们可以在这个$n*m$的矩阵中选择$k$个点标记为$1$. 我们要选择一个最佳的标记策略,使得 ...
- CF605E Intergalaxy Trips 贪心 概率期望
(当时写这篇题解的时候,,,不知道为什么,,,写的非常冗杂,,,不想改了...) 题意:一张有n个点的图,其中每天第i个点到第j个点的边都有$P_{i, j}$的概率开放,每天可以选择走一步或者留在原 ...
- CF623D birthday 贪心 概率期望
题意:n个人,玩抓人游戏,每抓住一个人都要猜这个人是谁.对于每一局,第i个人有$p_{i}$的概率被抓到.游戏结束当且仅当每个人都在某局中被抓到并且猜中自己的名字,求一个合适的策略来使得期望游戏局数最 ...
- luoguP3232 [HNOI2013]游走 贪心 + 概率期望 + 高斯消元
首先,题目中的无向简单连通图代表着没有自环,重边... 总分的期望 = 每条边的期望之和...................每条边的期望又可以拆成$u \to v$的期望和$v \to u$的期望 ...
- Codeforces 1045D Interstellar battle 概率期望
原文链接https://www.cnblogs.com/zhouzhendong/p/CF1045D.html 题目传送门 - CF1045D 题意 给定一棵有 $n$ 个节点的树,第 $i$ 个节点 ...
- Codeforces - 1264C - Beautiful Mirrors with queries - 概率期望dp
一道挺难的概率期望dp,花了很长时间才学会div2的E怎么做,但这道题是另一种设法. https://codeforces.com/contest/1264/problem/C 要设为 \(dp_i\ ...
- CodeForces - 28C Bath Queue 概率与期望
我概率期望真是垃圾--,这题搞了两个钟头-- 题意 有\(n\)个人,\(m\)个浴室,每个浴室里有\(a_i\)个浴缸.每个人会等概率随机选择一个浴室,然后每个浴室中尽量平分到每个浴缸.问期望最长排 ...
- [Codeforces 553E]Kyoya and Train(期望DP+Floyd+分治FFT)
[Codeforces 553E]Kyoya and Train(期望DP+Floyd+分治FFT) 题面 给出一个\(n\)个点\(m\)条边的有向图(可能有环),走每条边需要支付一个价格\(c_i ...
- 【BZOJ3143】【HNOI2013】游走 && 【BZOJ3270】博物馆 【高斯消元+概率期望】
刚学完 高斯消元,我们来做几道题吧! T1:[BZOJ3143][HNOI2013]游走 Description 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小 ...
随机推荐
- Synchronized底层优化(轻量级锁、偏向锁)(二)
一.重量级锁 上篇文章中向大家介绍了Synchronized的用法及其实现的原理.现在我们应该知道,Synchronized是通过对象内部的一个叫做监视器锁(monitor)来实现的.但是监视器锁本质 ...
- k8s-kubernetes-configmap存储
存储 configMap configMap描述信息 ConfigMap功能在Kubernetes1.2版本中引入,许多应用程序会从配置文件.命令行参数或环境变量中读取配置信息. ConfigMap ...
- python 并发编程 异步IO模型
异步IO(Asynchronous I/O) Linux下的asynchronous IO其实用得不多,从内核2.6版本才开始引入.先看一下它的流程: 用户进程发起read操作之后,立刻就可以开始去做 ...
- Notepad++ 不打开历史文件
1. 自己的很多虚拟机上面安装了notepad++ 提高编辑文件的速度. 但是发现 有时候总是默认打开 很多 历史文件 会造成很卡顿. 2. 解决办法 如下图 设置->首选项 3. 具体的位置为 ...
- c语言程序命名规范:函数、变量、数组、文件名
函数: //send or recv data task void send_recv_data(void *pvParameters); //get socket error code. retur ...
- 使用Koa.js离不开这十个中间件
随着ES6的普及,async/await的语法受到更多JS开发者的青睐,Koa.js作为比较早支持使用该语法的Node框架越来越受到大家的喜爱,虽然Koa.js本身支持的功能很有限,但官方和社区提供了 ...
- java springmvc poi 导出Excel,先简单记录,后期会详细描写
POI jar包下载 : http://poi.apache.org/download.html jsp代码 <%@ page language="java" content ...
- OpenCV处理文件、视频和摄像头
图像的本质(图像可以用数组来表示) import numpy as np import cv2 img = np.zeros((3, 3), dtype=np.uint8) print(img, im ...
- npm命令的使用
本人实际项目开发前端用的是单页vue组件开发.不管是启动项目还是下载依赖,都要使用npm命令. 东凑凑,西拼拼,整理些常用的. 前提:需要下载node.js.这里就不详细说明了.具体参照官方文档. 1 ...
- qt table中字体倾斜
在itemdelegate,的paint事件中添加 QStyleOptionViewItem newOption(option); QTransform transfor ...