随机游动算法解决kSAT问题

news2025/7/24 9:58:03

input:n个变量的k-CNF公式

ouput:该公式的一组满足赋值或宣布没有满足赋值

算法步骤:

  1. 随机均匀地初始化赋值 a ∈ { 0 , 1 } n a\in\{0,1\}^n a{0,1}n.
  2. 重复t次(后面会估计这个t):
    a. 如果在当前赋值下公式满足,则停止并输出满足赋值;
    b. 找到某个C是不可满足的子句;
    c. 显然C中不超过k个文字,随机选择其中一个,改变其赋值.

以上就是完整算法,很简洁且暴力。下面主要分析它的时间复杂度。

首先问题变量的状态空间是 2 n 2^n 2n的(每个变量取0或1),所以其穷举算法的时间为 O ( 2 n ) O(2^n) O(2n)。而上述的随机游动算法可以将这个底数2优化为 c ∈ ( 1 , 2 ) c\in(1,2) c(1,2)即时间复杂度为 O ( c n ) O(c^n) O(cn),因此我们称其为改进的指数时间算法。这对于kSAT这些npc问题是很好的优化了。下面我们找出这个c的表达式。

Part 1:

假设公式可满足,某个满足赋值为 x ∗ x^* x,定义随机变量X为当前赋值 x x x x ∗ x^* x不同变量的个数,显然X服从二项分布B(n,0.5).当X=d时,将 x x x变成 x ∗ x^* x​需要改变赋值的变元个数为d.

赋值改变这个过程可以看成马尔科夫链,状态0,1,…,n表示 x x x x ∗ x^* x之间的汉明距离(i.e. 不同变量的个数),算法步骤1的随机初始化就是从开始状态到状态d,转移概率为 C n j 2 − n C^j_n2^{-n} Cnj2n.

算法步骤2.3中因为C是不可满足的子句,在C中的至多k个变量中,至少有一个的赋值和 x ∗ x^* x不同,该操作从状态d到d-1的概率至少为 p = 1 k p=\frac{1}{k} p=k1,到d+1的概率至多为 1 − p = k − 1 k 1-p=\frac{k-1}{k} 1p=kk1.至此我们得到了一个广义的Gambler’s ruin问题.

在这里插入图片描述
Part 2:

定义从状态d随机移动到状态0的概率为 P ( d ) P(d) P(d)​,从Part 1的讨论中我们可以得到问题的转移方程:
P ( d ) = p P ( d − 1 ) + ( 1 − p ) P ( d + 1 ) P(d)=pP(d-1)+(1-p)P(d+1) P(d)=pP(d1)+(1p)P(d+1)
其中 P ( 0 ) = 1 P(0)=1 P(0)=1.(区别于赌徒破产问题,我们只有状态0这一个吸收态)虽然状态没有拓扑序,无法从初始状态直接递推,但注意到这是一个线性齐次递推式,我们可以通过解对应的特征方程 ( 1 − p ) r 2 − r + p = 0 (1-p)r^2-r+p=0 (1p)r2r+p=0构造通解。方程的两个根为 p 1 − p \frac{p}{1-p} 1pp 1 1 1. 我们有:
P ( n ) = A ( p 1 − p ) n + B ( 1 ) n = A ( p 1 − p ) n + B P(n)=A\left(\frac{p}{1-p}\right)^n+B(1)^n=A\left(\frac{p}{1-p}\right)^n+B P(n)=A(1pp)n+B(1)n=A(1pp)n+B
代入 P ( 0 ) = 1 P(0)=1 P(0)=1 A + B = 1 A+B=1 A+B=1,同时由于概率的非负性, A < 1 A<1 A<1否则我们一定可以找到一个n使得 P ( n ) < 0 P(n)<0 P(n)<0,这样我们可以得到一个下界:
P ( d ) = A ( p 1 − p ) d + 1 − A ≥ ( p 1 − p ) d P(d)=A\left(\frac{p}{1-p}\right)^d+1-A\geq\left(\frac{p}{1-p}\right)^d P(d)=A(1pp)d+1A(1pp)d
代入p得到 P ( d ) ≥ ( k − 1 ) − d P(d)\geq(k-1)^{-d} P(d)(k1)d

Part 3:

所以当满足赋值为 x ∗ x^* x存在时,我们通过随机游动找到它的概率为:
P ∗ ≥ ∑ d n C n d 2 − n ( k − 1 ) − d = 2 − n ( 1 + 1 k − 1 ) n ( 二项式定理 ) P^*\geq \sum_{d}^{n} C^d_n2^{-n}(k-1)^{-d}=2^{-n}\left(1+\frac{1}{k-1}\right)^n(二项式定理) PdnCnd2n(k1)d=2n(1+k11)n(二项式定理)
因此重复次数t的期望为 1 P ∗ \frac{1}{P^*} P1,算法的复杂性为
p o l y ( n ) × 1 P ∗ = p o l y ( n ) × ( 2 ( 1 − 1 k ) ) n poly(n)\times\frac{1}{P^*}=poly(n)\times\left(2\left(1-\frac{1}{k}\right)\right)^n poly(n)×P1=poly(n)×(2(1k1))n
以上,我们通过随机游动算法给出了kSAT的改进的指数时间的随机算法.

参考材料:

屈婉玲, 刘田, 张立昂, 王捍贫. 算法设计与分析习题解答与学习指导[M]. 第2版. 北京: 清华大学出版社, 2016.3. ISBN 9787302364924.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2397446.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《Discuz! X3.5开发从入门到生态共建》第1章 Discuz! 的前世今生-优雅草卓伊凡

《Discuz! X3.5开发从入门到生态共建》第1章 Discuz! 的前世今生-优雅草卓伊凡 第一节 从康盛创想到腾讯收购&#xff1a;PC时代的辉煌 1.1 Discuz! 的诞生&#xff1a;康盛创想的开源梦想 2001年&#xff0c;中国互联网正处于萌芽阶段&#xff0c;个人网站和论坛开始兴起。…

笔试强训:Day6

一、小红的口罩&#xff08;贪心优先级队列&#xff09; 登录—专业IT笔试面试备考平台_牛客网 #include<iostream> #include<queue> #include<vector> using namespace std; int n,k; int main(){//用一个小根堆 每次使用不舒适度最小的cin>>n>&…

谷歌Stitch:AI赋能UI设计,免费高效新利器

在AI技术日新月异的今天&#xff0c;各大科技巨头都在不断刷新我们对智能工具的认知。最近&#xff0c;谷歌在其年度I/O开发者大会期间&#xff0c;除了那些聚光灯下的重磅发布&#xff0c;还悄然上线了一款令人惊喜的AI工具——Stitch。这是一款全新的、完全免费的AI驱动UI&am…

运营商地址和ip属地一样吗?怎么样更改ip属地地址

‌在互联网时代&#xff0c;IP属地和运营商地址是两个经常被提及的概念&#xff0c;但它们是否相同&#xff1f;如何更改IP属地地址&#xff1f;这些问题困扰着许多网民。本文将深入探讨这两个概念的区别&#xff0c;并详细介绍更改IP属地地址的方法。 一、运营商地址和IP属地一…

在QT中,利用charts库绘制FFT图形

第1章 添加charts库 1.1 .pro工程添加chart库 1.1.1 在.pro工程里面添加charts库 1.1.2 在需要使用的地方添加这两个库函数&#xff0c;顺序一点不要搞错&#xff0c;先添加.pro&#xff0c;否则编译器会找不到这两个.h文件。 第2章 Charts关键绘图函数 2.1 QChart 类 QChart 是…

流媒体协议分析:流媒体传输的基石

在流媒体传输过程中&#xff0c;协议的选择至关重要&#xff0c;它决定了数据如何封装、传输和解析&#xff0c;直接影响着视频的播放质量和用户体验。本文将深入分析几种常见的流媒体传输协议&#xff0c;探讨它们的特点、应用场景及优缺点。 协议分类概述 流媒体传输协议根据…

vscode中让文件夹一直保持展开不折叠

vscode中让文件夹一直保持展开不折叠 问题 很多小伙伴使用vscode发现空文件夹会折叠显示, 让人看起来非常难受, 如下图 解决办法 首先打开设置->setting, 搜索compact Folders, 去掉勾选即可, 如下图所示 效果如下 看起来非常爽 ! ! !

JAVA-springboot整合Mybatis

SpringBoot从入门到精通-第15章 MyBatis框架 学习MyBatis心路历程 2022年学习java基础时候&#xff0c;想着怎么使用java代码操作数据库&#xff0c;咨询了项目上开发W同事&#xff0c;没有引用框架&#xff0c;操作数据库很麻烦&#xff0c;就帮我写好多行代码&#xff0c;就…

深度学习pycharm debug

深度学习中&#xff0c;Debug 是定位并解决代码逻辑错误&#xff08;如张量维度不匹配&#xff09;、训练异常&#xff08;如 Loss 波动&#xff09;、数据问题&#xff08;如标签错误&#xff09;的关键手段&#xff0c;通过打印维度、可视化梯度等方法确保模型正常运行、优化…

MicroPython+L298N+ESP32控制电机转速

要使用MicroPython控制L298N电机驱动板来控制电机的转速&#xff0c;你可以通过PWM&#xff08;脉冲宽度调制&#xff09;信号来调节电机速度。L298N是一个双H桥驱动器&#xff0c;可以同时控制两个电机的正反转和速度。 硬件准备&#xff1a; 1. L298N 电机控制板 2. ESP32…

在部署了一台mysql5.7的机器上部署mysql8.0.35

在已部署 MySQL 5.7 的机器上部署 MySQL 8.0.35 的完整指南 在同一台服务器上部署多个 MySQL 版本需要谨慎规划&#xff0c;避免端口冲突和数据混淆。以下是详细的部署步骤&#xff1a; 一、规划配置 端口分配 MySQL 5.7&#xff1a;使用默认端口 3306MySQL 8.0.35&#xff1…

QT入门学习(一)---新建工程与、信号与槽

一: 新建QT项目 二:QT文件构成 2.1 first.pro 项目管理文件&#xff0c;下面来看代码解析 QT core guigreaterThan(QT_MAJOR_VERSION, 4): QT widgetsCONFIG c11TARGET main# The following define makes your compiler emit warnings if you use # any Qt feature …

UE5.4.4+Rider2024.3.7开发环境配置

文章目录 一、UE5安装 安装有两种方式一种的源码编译安装、一种是EPIC安装&#xff0c;推荐后者&#xff0c;只需要注册一个EPIC账号就可以一键安装。 二、C环境安装 1.下载VisualStudioSetup 下载链接如下下载 Visual Studio Tools - 免费安装 Windows、Mac、Linux 选择社…

Windows环境下PHP,在PowerShell控制台输出中文乱码

解决方法&#xff1a; 以管理员运行PowerShell , 输入&#xff1a; chcp 65001 重启控制台&#xff1b;然后就正常输出中文&#xff1b;

性能优化 - 理论篇:性能优化的七类技术手段

文章目录 Pre引言性能优化的七类技术手段性能优化策略一览表1. 复用优化2. 计算优化2.1 并行执行2.2 变同步为异步2.3 惰性加载 3. 结果集优化3.1 数据格式与协议选择3.2 字段精简与按需返回3.3 批量处理与分页3.4 索引与位图加速 4. 资源冲突优化4.1 锁的分类与特点4.2 无锁与…

华为IP(7)

端口隔离技术 产生的背景 1.以太交换网络中为了实现报文之间的二层隔离&#xff0c;用户通常将不同的端口加入不同的VLAN&#xff0c;实现二层广播域的隔离。 2.大型网络中&#xff0c;业务需求种类繁多&#xff0c;只通过VLAN实现二层隔离&#xff0c;会浪费有限的VLAN资源…

AIGC与影视制作:技术革命、产业重构与未来图景

文章目录 一、AIGC技术全景&#xff1a;从算法突破到产业赋能1. **技术底座&#xff1a;多模态大模型的进化路径**2. **核心算法&#xff1a;从生成对抗网络到扩散模型的迭代** 二、AIGC在影视制作全流程中的深度应用1. **剧本创作&#xff1a;从“灵感枯竭”到“创意井喷”**2…

Cursor 玩转 腾讯地图 MCP Server

腾讯地图WebService API 服务简介 腾讯地图WebService API 是基于HTTPS/HTTP协议构建的标准化地理数据服务接口。该接口支持跨平台调用&#xff0c;开发者可使用任意客户端、服务器端技术及编程语言&#xff0c;遵循API规范发起HTTPS请求&#xff0c;获取地理信息服务&#xf…

2025年中国电商618年中大促策略分析:存量博弈与生态重构

图片来源&#xff1a;Photo by Samuel Regan-Asante on Unsplash 中国电商行业正经历一场从「增量扩张」到「存量深耕」的深刻转型。 随着网络购物用户规模突破9.74亿、线上消费渗透率逼近30%的临界点&#xff0c;传统流量红利逐渐消退&#xff0c;行业竞争已从「切蛋糕」转向…

Deepseek给出的8255显示例程

#include <stdio.h> #include <conio.h> #include <dos.h>// 定义8255端口地址 (根据原理图译码确定) #define PORT_8255_A 0x8000 // PA端口地址 #define PORT_8255_B 0x8001 // PB端口地址 #define PORT_8255_C 0x8002 // PC端口地址 #define PORT_8255…