脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|shell|

服务器之家 - 脚本之家 - Python - python 动态规划问题解析(背包问题和最长公共子串)

python 动态规划问题解析(背包问题和最长公共子串)

2023-01-27 13:27yetangjian Python

这篇文章主要介绍了python 动态规划(背包问题和最长公共子串),在动态规划中,你要将某个指标最大化。在这个例子中,你要找出两个单词的最长公共子串。fish和fosh都包含的最长子串是什么呢,感兴趣的朋友跟随小编一起看看吧

背包问题

现在要往一个可以装4个单位重量的背包里怎么装价值最高:A重量1个单位,价值15;B重量3个单位,价值20;C重量4个重量,价值30

使用动态规划填充空格

python 动态规划问题解析(背包问题和最长公共子串)

class SolutionBag:
  def valuableBag(self,optionalList,sizeBig):
      #创建网格
      grid = [[0 for i in range(sizeBig+1)] for j in range(len(optionalList)+1)]
      #从行列序号1开始计数
      column = 1
      for v in optionalList.values():
          optionalWeight,optionalPrice = v
          for row in range(sizeBig):
              if optionalWeight > row+1:
                  grid[column][row+1] = grid[column-1][row+1]
              else:
                  grid[column][row+1] = max(grid[column-1][row+1],optionalPrice+grid[column-1][row+1-optionalWeight])
          column += 1
      return grid#SolutionBag().valuableBag({"A":(1,15),"B":(3,20),"C":(4,30)},4)

 

最长公共子串

在动态规划中,你要将某个指标最大化。在这个例子中,你要找出两个单词的最长公共子串。fish和fosh都包含的最长子串是什么呢

如何将这个问题划分为子问题呢?你可能需要比较子串:不是比较hish和fish,而是先比较his和fis

我们网格填充的方法来实现

python 动态规划问题解析(背包问题和最长公共子串)

#伪代码
#字母相同则左上方+1
if word1[i] == word2[j] :
  cell[i][j] = cell[i-1][j-1] +1
else:
  cell[i][j] = max(cell[i][j-1],cell[i-1][j])

python实现网格

class SolutionLengthS:
  def longestLength(self,str1,str2):
      grid = [[0 for j in range(len(str2)+1)] for i in range(len(str1)+1)]
      for i in range(len(str2)):
          for j in range(len(str1)):
              if str1[j] == str2[i] :
                  grid[i+1][j+1] = grid[i][j] + 1
              else:
                  grid[i+1][j+1] = max(grid[i+1][j],grid[i][j+1])
      return grid

到此这篇关于python 动态规划(背包问题和最长公共子串)的文章就介绍到这了,更多相关python 动态规划内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/yetangjian/p/16268741.html

延伸 · 阅读

精彩推荐
  • Python使用python来调用CAN通讯的DLL实现方法

    使用python来调用CAN通讯的DLL实现方法

    今天小编就为大家分享一篇使用python来调用CAN通讯的DLL实现方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    caimouse9292021-07-30
  • PythonPython实现的绘制三维双螺旋线图形功能示例

    Python实现的绘制三维双螺旋线图形功能示例

    这篇文章主要介绍了Python实现的绘制三维双螺旋线图形功能,结合实例形式分析了Python使用matplotlib、numpy模块进行数值运算及图形绘制相关操作技巧,需要的...

    水之魂20188192021-03-08
  • PythonPython实现的文轩网爬虫完整示例

    Python实现的文轩网爬虫完整示例

    这篇文章主要介绍了Python实现的文轩网爬虫,结合完整实例形式分析了Python爬虫爬取文轩网图书信息的相关操作技巧,需要的朋友可以参考下...

    小鹏程序10452021-06-27
  • Python在Python的列表中利用remove()方法删除元素的教程

    在Python的列表中利用remove()方法删除元素的教程

    这篇文章主要介绍了在Python的列表中利用remove()方法删除元素的教程,是Python入门中的基础知识,注意其和pop()方法的区别,需要的朋友可以参考下 ...

    脚本之家9842020-07-04
  • PythonPython 中利用Pandas处理复杂的Excel数据

    Python 中利用Pandas处理复杂的Excel数据

    在本文中,我们介绍了在Pandas下通过参数轻松删除行和列以使其格式更加合理。 ...

    今日头条34532020-10-29
  • PythonPython中的装饰器用法详解

    Python中的装饰器用法详解

    这篇文章主要介绍了Python中的装饰器用法,以实例形式详细的分析了Python中的装饰器的使用技巧及相关注意事项,具有一定参考借鉴价值,需要的朋友可以参考...

    脚本之家2572020-05-19
  • Python详解Python中expandtabs()方法的使用

    详解Python中expandtabs()方法的使用

    这篇文章主要介绍了详解Python中expandtabs()方法的使用,是Python入门中的基础知识,需要的朋友可以参考下 ...

    Python教程网3672020-07-01
  • PythonPython绘制分类图的方法

    Python绘制分类图的方法

    这篇文章主要为大家详细介绍了Python绘制分类图的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    江北201904114202021-10-14