码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 算法 Hw8


    Hw 8

    • 1 String matching
      • 1
      • 2
    • Prefix and suffix tree
      • 1
      • 2
      • 3
        • a
        • b
    • 3 Reduction
      • 1

    1 String matching

    1

    f = { 0 , 0 , 1 , 2 , 0 , 1 , 2 , 0 , 1 , 2 , 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 } f=\{0,0,1,2,0,1,2,0,1,2,0,1,2,3,4,5,6,7,8\} f={0,0,1,2,0,1,2,0,1,2,0,1,2,3,4,5,6,7,8}


    2

    ∣ f ∗ [ q ] ∣ < q ∣f∗ [q]∣∣f∗[q]∣<q

    当字符串 P P P 全是相同的字符时, ∣ f ∗ [ q ] ∣ = q − 1 < q ∣f∗ [q]∣=q-1∣f∗[q]∣=q−1<q


    Prefix and suffix tree

    1

    在这里插入图片描述


    2

    在这里插入图片描述


    3

    a

    后缀树的空间复杂度是 O ( n l o g n ) O(nlogn) O(nlogn)
    因为在最坏情况下,每个节点可能需要存储⼀个指向文本的引⽤和⼀些附加信息

    b

    通过使用引用索引,可以将空间复杂度优化到 O ( n ) O(n) O(n)。
    具体来说,可以通过在每个节点中存储文本的起始位置和长度来引用整个文本,从而避免存储重复的子串。


    3 Reduction

    1

    对于每个布尔变量,创建⼀个有向图中的节点,分别表示该变量及其否定形式。
    对于每个子句中的文字,创建⼀个有向图中的节点,分别表示该文字及其否定形式。
    对于每个子句,创建⼀个大小为 3 3 3 的路径,连接对应⽂字的节点。这个路径确保了只能选择其中⼀个文字的赋值。
    对于相邻子句中相同的文字,连接它们对应的节点,以确保它们不能同时为真。
    连接前⼀步中生成的节点到⽬标顶点 t t t。这样建立⼀个有向图,其中每个布尔变量和每个子句都有对应的节点,而每个可能的布尔赋值都对应于从起始节点 s s s 到目标节点 t t t 的⼀条路径。并且,由于每个子句中只能选择⼀个文字为真,所以这些路径是简单路径。 这个转换可以在多项式时间内完成,因此 3 − S a t ≤ p L o n g e s t − P a t h 3-Sat ≤p Longest-Path 3−Sat≤pLongest−Path

  • 相关阅读:
    react代码编译+部署完成,运行前:如何修改配置文件以改变代码中对应变量的值?
    Impedit odio facilis ad.Quinze également passer billet mensonge animer libre.
    【算法挨揍日记】day13—— DP34 【模板】前缀和、DP35 【模板】二维前缀和
    以汇川中型PLC(AM系列)为例,CODESYS平台变量与字节数组互转的多种方法
    Kafka - 3.x 文件存储不完全指北
    51单片机STC89C52RC——9.1 DS1302涓流充电计时芯片
    Java数据结构-优先级队列
    【知识图谱 新词挖掘1】python实现-附ChatGPT解析
    leetcode 268. 丢失的数字(异或!!)
    C语言易错知识点:scanf函数
  • 原文地址:https://blog.csdn.net/sereinXH/article/details/139425987
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号