首页 > 其他分享 >随机打乱

随机打乱

时间:2023-01-15 10:34:59浏览次数:44  
标签:... 打乱 显然 算法 随机 pi dp

概述

  • 某些题目的数据,如果顺序随机,将会有非常美妙的结论。

  • 但显然,除非写了“保证数据随机”(事实上,没给 generator 的随机都可以认为是构造...),否则出题人不会这样给数据。

  • 此时就要考虑将数据重排,以获得较优的效果。

如何随机打乱?

  • 给出一种均匀随机的打乱算法及证明:
template <typename T>
il void ran(T a[],int n){
	foR(i,n,2) 
		swap(a[i],a[_rand()%i+1]);
	return;
}
  • 显然,当 \(n=1\),该算法均匀随机。接下来我们考虑归纳证明。

  • 首先,我们可以把上面那个算法改写成递归形式:

template <typename T>
il void ran(T a[],int n){
	if(n==1) return;
	swap(a[n],a[_rand()%n+1]);
	ran(a,n-1);
	return;
}
  • 显然,“均匀随机”等价于对于所有的 \(n\) 的排列 \(\pi,P(a_{[1,n]=\pi})=\dfrac{1}{n!}\)。

  • 尝试归纳证明。

  • 考虑把 \(n+1\) 的排列中的 \(n+1\) 删去,发现恰有 \(n+1\) 种 \(\pi'\)(分别对应 \(n+1\) 在 \(1,2,\dots,n+1\))在删除后得到的 \(\pi\) 相同,且这些 \(\pi'\) 不同。

  • 从而得证,对于所有的 \(n+1\) 的排列 \(\pi',P(a_{1,n+1}=\pi')=\dfrac{1}{(n+1)!}\)。故该算法均匀随机。

  • 当然,也可以用 random_shuffle,该函数内部实现其实就是上面的算法。可以在 笔记-语法 里找到。

例题

P7606 混乱邪恶

  • 题意:

    • 给定一个六边形网格图。可以认为初始时在 \((0,0)\)。你有两种属性 \((L,G)\),初始时属性为 \((0,0)\)。

    • 可以移动 \(n\) 次,每次移动有六种决策,第 \(i\) 种会使属性改变 \((\Delta_{i,1},\Delta_{i,2})\)(直接相加)。这里的加法是在 \(\bmod\ p\) 意义下进行的。

    • 问是否存在一种方案,使得在 \(n\) 步后回到 \((0,0)\),且属性为给出的 \((L^* ,G^* )\)。

  • 数据范围:

    • \(1\leqslant n,p\leqslant 100\)。

    • 其他数据 \(<p\)。

    • \(700ms\) 时限。

  • 首先我们需要对六边形网格图进行坐标规定,否则没法做。一个常见的编码方法是:

    • 右上,\((+1,+1)\)。

    • 右,\((+1,0)\)。

    • 右下,\((0,-1)\)。

    • 左下,\((-1,-1)\)。

    • 左,\((-1,0)\)。

    • 左上,\((0,+1)\)。

  • 其实就是认为右是 \(x\) 轴正方向,左上是 \(y\) 轴正方向,右上是 \(l:y=x\)。当然编码方式很多的,随便用一个就好啦。

  • 然后...然后这个东西怎么看都很 dp 吧?

    • 状态设计:\(dp_{i,x,y,L,G}\) 表示走了 \(i\) 步,当前在 \((x,y)\),当前的属性为 \((L,G)\),可不可行。

    • 初始化:\(dp_{0,0,0,0,0}=1\)。

    • 递推转移:\(dp_{i,x,y,L,G}\to dp_{i+1,x+dx,y+dy,L+dl,G+dg}\)。

  • 状态数 \(n^5\),转移 \(O(6)\) 不过可能跑不满。但这显然无法接受...考虑用 bitset 压一下,于是大约 \(10^9\) 的复杂度,还是无法接受啊?

  • 注意到一个显然的事情,如果 \((x,y)\) 中某一维的绝对值大于还能走的步数,该状态无意义。毕竟走不回来。虽然如此,状态还是挺密集的,分层图 bfs 大概是负优化。

  • 铛铛!有一个重要结论:随机游走 \(n\) 步恰回到起点的坐标绝对值期望为 \(\sqrt{n}\)。可以证但我不会,原命题是一维数轴或二维平面情况,但显然推广到这里也是对的。

  • 考虑随机重排所有决策,显然,决策的顺序对结果没有影响。从而接下来就是一个接近随机游走的情况啦!

  • 可以把 \(dp\) 的第二,三维都开到 \(2\sqrt{n}\) 多一点就好。于是复杂度肯定是 \(O(\text{能过})\),额...大概 \(4\times10^7\)?

平面最近点对(系列)

  • 见随机排序。

标签:...,打乱,显然,算法,随机,pi,dp
From: https://www.cnblogs.com/weixin2024/p/17053155.html

相关文章

  • 随机排序
    概述如果元素满足某种序,那么在排序后我们可以直接得到答案。但事实上,大部分情况下没有这么优美的结论。虽然如此,我们还是可以猜测将元素按某种逻辑排序后,答案的来源(......
  • 随机选择
    概述随机选择通过随机地取总数据的某一部分,来尝试着获取总体数据或总体数据的代表性部分的信息,恰如抽样调查。例题CodeChefMSTONE题意:给出落在\(7\)条直线上的......
  • 随机探测
    概述随机探测通过用随机的探针测试某个黑箱,来获得该黑箱高度可能的状态。太抽象?没关系。就来例题。例题测素给定一个数,判断它是否是质数。我们知道,由费马......
  • NIST随机性测试套件下载,安装,实验
    参考博客NIST随机性测试美国国家标准与技术研究所提供的测试,一共包括16种测试手段,具体内容可参考此博客NIST下载与安装环境:Windows11下载:NIST官网链接点击downlo......
  • 随机过程的思维导图和笔记
    简单梳理了一下随机过程前四章的内容,这四章联系还是很紧密的。以第一章为基础,延伸出第二章的多种poisson过程,包括复合、稀释、叠加以及条件分布的poisson过程。第三章应用......
  • 洛谷 P3600 随机数生成器
    洛谷传送门设\(h_i\)为所有询问最大值\(\lei\)的方案数,则\(ans=\dfrac{\sum\limits_{i=1}^ni\times(h_i-h_{i-1})}{x^n}\)。设\(g_i\)为在\(1\simn\)......
  • PYTHON 用几何布朗运动模型和蒙特卡罗MONTE CARLO随机过程模拟股票价格可视化分析耐克
    原文链接:http://tecdat.cn/?p=27099最近我们被客户要求撰写关于模拟股票价格的研究报告,包括一些图形和统计输出。金融资产/证券已使用多种技术进行建模。该项目的主要目......
  • php 获取指定目录下面的某个随机文件名
    //获取指定目录下面的某个随机文件名functiongetRandomFileName($directory){$mydir=dir($directory);$files=array();while($file=$mydir->read()){......
  • Jmeter学习:定时器--固定定时器/随机定时器/准确吞吐量定时器
    一、固定定时器功能:通过该定时器,我们可以对每一个线程延迟固定时间。 二、随机定时器功能:通过该定时器,我们可以对每一个线程随机延迟一定时间。总体延迟时间=随机时......
  • 使用 HTML、CSS 和 JavaScript 制作的随机密码生成器
    ----上图  ------MVC创建的视图,视图名称为A@{Layout=null;}<!DOCTYPEhtml><styletype="text/css">*{margin:0;padding:0;......