浅谈Meet in the middle——MITM
目测观看人数 \(0+0+0=0\)
\(\mathrm{Meet\;in\;the\;middle}\)(简称 \(\rm MITM\)),顾名思义就是在中间相遇。
可以理解为就是起点跑搜索树基本一半的状态,终点也跑搜索树基本一半的状态,最后撞到中间,一种类似双向 DFS 的东西。优化还是不错的awa,减少了差不多一半。

时间复杂度可如下分析:
设向外搜索 \(n\) 层需要的代价为 \(k(n)\)。如果不用 \(\textrm{MITM}\),那么复杂度显然是 \(\mathcal O(k(n))\)。
以下提供两种做法:
- 方法 \(1\):由 \(\rm MITM\) 定义得,从起点搜索到一半的代价为 \(k\left(\dfrac{n}{2}\right)\),从终点搜索到一半的代价也为 \(k\left(\dfrac{n}{2}\right)\),总代价为 \(2\cdot k\left(\dfrac{n}{2}\right)\),省略常数,得时间复杂度 \(\mathcal O\left(k\left(\dfrac{n}{2}\right)\right)\)。
- 方法 \(2\):设搜索树起点与终点为 \(A,B\) 连接 \(B\) 与搜索树左右边缘中点,再连接两个左右边缘中点,将搜索树分为四个面积相等区块,\(\rm MITM\) 仅搜索其中两个区块,得时间复杂度为 \(\mathcal O\left(k\left(\dfrac{n}{2}\right)\right)\)。
这种算法吧,对于 \(k(n)=n^2\) 时,朴素算法为 \(n^2\),\(\rm MITM\) 为 \(\left(\dfrac{n}{2}\right)^2=\dfrac{n^2}{4}\),优化了 \(\dfrac{1}{4}\) 复杂度。线性的优化,在数据大时效果明显。但是如果 \(k(n)=2^n\),那么朴素算法为 \(2^n\),\(\rm MITM\) 为 \(2^{\frac{n}{2}}=\sqrt{2^n}\)。
显然从一个节点出发进行搜索这题肯定会超时的
对于一个 \(9\) 位数,一共有 \(9\) 种可能的 \(+1\) 操作(每一个数位都可以 \(+1\)),一共有 \(8\) 种可能的交换操作,共 \(17\) 种操作。乘法原理得如果向外搜 \(10\) 层复杂度是 \(17^{10}\)使用某 Windows 常用计算小工具得 \(17^{10}=2015993900449\) 假设计算机 \(1ms\) 运行 \(10^4\) 次操作还是不能 \(1s\) 解决,显然 \(\bold{\rm TLE}\)。
告诉起始点来个 \(\rm MITM\) 双向就珂以了,\(17^5=1419857\),就算是 \(1ms\) 跑 \(10^2\) 的老爷机跑的差不多才 \(0.1s\)。
这题 \(\rm BFS\) 可能会浪费点时间还是 \(\rm DFS\) 好awa
注意用个 \(\rm hash\),别 \(\rm MLE\) 了
- 例题2
原题在 \(\rm codevs\) 众所周知 \(\rm codevs\) \(\dots\dots\)
有 \(n\) 个砝码,现在要称一个质量为 \(m\) 的物体,请问最少需要挑出几个砝码来称?
注意一个砝码最多只能挑一次。\(1\le n\le 30\),\(1\le m\le 2^{31}\),\(1\le \text{每个砝码的质量}\le 2^{30}\)
看起来像是背包??(
解法 \(1\):暴!力!出!奇!迹!一发爆搜切!掉!!
记得优化awa- 用后缀和优化
- 用读优
- 如果当前使用的砝码数 \(\ge\) 当前最优解,\(\rm return\)(最优性剪枝);
- 深搜之前按从大到小排序(改变搜索顺序),\(\text{当前总重量}+\text{当前砝码重量}<m\)(最优性剪枝) ,\(\rm return\);
- 如果 \(\text{当前总重量}+\text{当前砝码重量}>m\) ,换下一个砝码(可行性剪枝),注意不要 \(\rm return\);
然后就可以写出代码了:

解法 \(2\):用 \(\rm MITM\),如果后 \(\dfrac{1}{2}\) 发现有 \(=m\) 的就更新答案,这个稳过,不用优化。
代码:

浅谈Meet in the middle——MITM的更多相关文章
- 【ASP.NET MVC系列】浅谈ASP.NET MVC 路由
ASP.NET MVC系列文章 [01]浅谈Google Chrome浏览器(理论篇) [02]浅谈Google Chrome浏览器(操作篇)(上) [03]浅谈Google Chrome浏览器(操作 ...
- 浅谈分词算法(3)基于字的分词方法(HMM)
目录 前言 目录 隐马尔可夫模型(Hidden Markov Model,HMM) HMM分词 两个假设 Viterbi算法 代码实现 实现效果 完整代码 参考文献 前言 在浅谈分词算法(1)分词中的 ...
- Meet in the middle学习笔记
Meet in the middle(MITM) Tags:搜索 作业部落 评论地址 PPT中会讲的很详细 当搜索的各项互不影响(如共\(n\)个物品前\(n/2\)个物品选不选和后\(n/2\)个物 ...
- 【http协议】浅谈
[http协议]浅谈 一. 概述 http,超文本传输协议(HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络协议. 请求与响应: 客户端发送请求,服务器端响应数 ...
- 浅谈分词算法基于字的分词方法(HMM)
前言 在浅谈分词算法(1)分词中的基本问题我们讨论过基于词典的分词和基于字的分词两大类,在浅谈分词算法(2)基于词典的分词方法文中我们利用n-gram实现了基于词典的分词方法.在(1)中,我们也讨论了 ...
- 浅谈 Fragment 生命周期
版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Fragment 文中如有纰漏,欢迎大家留言指出. Fragment 是在 Android 3.0 中 ...
- 浅谈 LayoutInflater
浅谈 LayoutInflater 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/View 文中如有纰漏,欢迎大家留言指出. 在 Android 的 ...
- 浅谈Java的throw与throws
转载:http://blog.csdn.net/luoweifu/article/details/10721543 我进行了一些加工,不是本人原创但比原博主要更完善~ 浅谈Java异常 以前虽然知道一 ...
- 浅谈SQL注入风险 - 一个Login拿下Server
前两天,带着学生们学习了简单的ASP.NET MVC,通过ADO.NET方式连接数据库,实现增删改查. 可能有一部分学生提前预习过,在我写登录SQL的时候,他们鄙视我说:“老师你这SQL有注入,随便都 ...
随机推荐
- python工具--获取盛科交换机端口模块类型,波长,传输距离等信息
交换机端口模块信息对应的OID节点为各厂商私有节点,获取其他厂商信息需要把OID进行替换 1 #! /usr/bin/env python 2 #-*-coding:utf-8-*- 3 import ...
- 【算法】归并排序(Merge Sort)(五)
归并排序(Merge Sort) 归并排序是建立在归并操作上的一种有效的排序算法.该算法是采用分治法(Divide and Conquer)的一个非常典型的应用.将已有序的子序列合并,得到完全有序的序 ...
- Python 中的内存管理
Python 中一切皆对象,这些对象的内存都是在运行时动态地在堆中进行分配的,就连 Python 虚拟机使用的栈也是在堆上模拟的.既然一切皆对象,那么在 Python 程序运行过程中对象的创建和释放就 ...
- .NET程序设计实验2
1.设计编写一个控制台应用程序,练习类的继承. (1) 编写一个抽象类 People,具有"姓名","年龄"字段,"姓名"属性,Work 方 ...
- GraphX 图计算实践之模式匹配抽取特定子图
本文首发于 Nebula Graph Community 公众号 前言 Nebula Graph 本身提供了高性能的 OLTP 查询可以较好地实现各种实时的查询场景,同时它也提供了基于 Spark G ...
- pycharm相关介绍
一.settings设置 1.搜font 设置字体 2.Keymap------快捷键 二.常用快捷键 1.Ctrl + Enter:在下方新建行但不移动光标: 2.Shift + Enter:在 ...
- 【Java面试】请你简单说一下Mysql的事务隔离级别
一个工作了6年的粉丝,去阿里面试,在第一面的时候被问到"Mysql的事务隔离级别". 他竟然没有回答上来,一直在私信向我诉苦. 我说,你只能怪年轻时候的你,那个时候不够努力导致现在 ...
- SpringBoot的浅浅配置和小整合
SpringBoot的浅浅配置和小整合 本文如题,就是浅浅记录一下学习的过程中一些过程,比较简单,并没有多少深度.谢谢! SpringBoot创建 从IDEA中新建项目或者模块.注意jdk版本,一般不 ...
- Redis的内存淘汰策略(八)
一:Redis的AOF是什么? 以日志的形式来记录每个写操作(读操作不记录),将Redis执行过的所有写指令记录下来(读操作不记录),只许追加文件但不可以改写文件,redis启动之初会读取该文件重新构 ...
- 自然常数e的由来以及计算机为什么是二进制
背景 昨晚我在看一本书,叫<数学极客>,看到第六章<e:不自然的自然数>,这个数最早开始接触应该是高一的时候,那时候问老师,这个数是怎么来的,老实说,和圆周率一样,是一个常 ...