当前位置: 首页 > wzjs >正文

保定网站建设公司g4560做网站服务器

保定网站建设公司,g4560做网站服务器,js网站页面效果代码,霍山有没有做建网站的文章目录算法过程Python实现算法过程 Dodgson不仅仅是一个数学家,其实他更著名的一个身份是作家,写出了著名的儿童文学作品《爱丽丝梦游仙境》。他发明文学作品时用笔名Lewis Carroll,发表数学论文时用Dodgson,所以很难把这两个名…

文章目录

  • 算法过程
  • Python实现

算法过程

  Dodgson不仅仅是一个数学家,其实他更著名的一个身份是作家,写出了著名的儿童文学作品《爱丽丝梦游仙境》。他发明文学作品时用笔名Lewis Carroll,发表数学论文时用Dodgson,所以很难把这两个名字联系起来。
  闲话不说了,先说说他的算法过程。总体来说,算法过程是一个类似于Chió算法的过程,把矩阵不断缩小,直到缩小到1×11\times 11×1的矩阵。但是细节与Chió算法有很大不同,Dodgson算法是每次缩小两阶。算法具体是如下过程:

  1. 先通过行倍加,让中心块interior没有0,中心块是一个(n−2)×(n−2)(n-2)\times (n-2)(n2)×(n2)的矩阵,这个中心块是原矩阵的子矩阵就叫做SSS吧。
  2. 把每相邻四个元素的行列式计算出来,组成一个(n−1)×(n−1)(n-1)\times (n-1)(n1)×(n1)的矩阵,记作矩阵BBB
  3. 还没完,把矩阵B的每相邻四个元素的行列式计算出来,这样组成一个(n−2)×(n−2)(n-2)\times (n-2)(n2)×(n2)的矩阵,记作矩阵CCC,把CCC的每个元素除于A的中心块的对应位置元素,得到矩阵DDD
  4. 如果D是1×11\times 11×1的矩阵,那么原矩阵的行列式就等于DDD的行列式。如果不是,再进行一轮迭代,就计算B的行列式,但是需要跳过第2步的计算,用D作为第2步计算的结果。

  我以一个5×55\times 55×5例子讲述这个过程:
A=(−11−1221−1223112−1−32−111111111)B=(01−622−4−6−3−33323−200)C=(−2−3030−66−3−360)D=(2−1515−633360)A= \begin{pmatrix}-1 & 1 & -1 & 2 & 2\\ 1 & -1 & 2 & 2 & 3\\ 1 & 1 & 2 & -1 & -3\\ 2 & -1 & 1 & 1 & 1\\ 1 & 1 & 1 & 1 & 1\\ \end{pmatrix}\\ B= \begin{pmatrix}0 & 1 & -6 & 2\\ 2 & -4 & -6 & -3\\ -3 & 3 & 3 & 2\\ 3 & -2 & 0 & 0\\ \end{pmatrix}\\ C= \begin{pmatrix}-2 & -30 & 30\\ -6 & 6 & -3\\ -3 & 6 & 0\\ \end{pmatrix}\\ D= \begin{pmatrix}2 & -15 & 15\\ -6 & 3 & 3\\ 3 & 6 & 0\\ \end{pmatrix}\\ A=1112111111122112211123311B=0233143266302320C=26330663030D=26315361530
  得到的结果D不是1×11\times 11×1的矩阵,那么计算B的行列式,但是把D作为第二步的运算结果:
A=(01−622−4−6−3−33323−200)B=(2−1515−633360)C=(−84−90−45−18)D=(2115−15−6)A= \begin{pmatrix}0 & 1 & -6 & 2\\ 2 & -4 & -6 & -3\\ -3 & 3 & 3 & 2\\ 3 & -2 & 0 & 0\\ \end{pmatrix}\\ B= \begin{pmatrix}2 & -15 & 15\\ -6 & 3 & 3\\ 3 & 6 & 0\\ \end{pmatrix}\\ C= \begin{pmatrix}-84 & -90\\ -45 & -18\\ \end{pmatrix}\\ D= \begin{pmatrix}21 & 15\\ -15 & -6\\ \end{pmatrix} A=0233143266302320B=26315361530C=(84459018)D=(2115156)
  DDD是一个2×22\times 22×2的矩阵还不行,还得缩小,再来:
A=(2−1515−633360)B=(2115−15−6)C=(99)D=(33)A= \begin{pmatrix}2 & -15 & 15\\ -6 & 3 & 3\\ 3 & 6 & 0\\ \end{pmatrix}\\ B= \begin{pmatrix}21 & 15\\ -15 & -6\\ \end{pmatrix}\\ C= \begin{pmatrix}99\\ \end{pmatrix}\\ D= \begin{pmatrix}33\\ \end{pmatrix} A=26315361530B=(2115156)C=(99)D=(33)
  最终结果出来了,是33.

Python实现

  我只贴相关核心代码,我的代码中没有判断中心块是否含有0,不过这是为了学习算法,而不是用于实际生产项目,所以我就没继续完善:

    def interior(self):# Dodgson算法的中心块子矩阵n = len(self.__vectors)array = [[0 for _ in range(n - 2)] for _ in range(n - 2)]# i 代表行 j代表列for i in range(0, n - 2):for j in range(0, n - 2):# 如果column = 0array[j][i] = self.__vectors[j + 1][i + 1]return Matrix(array)def dodgson_condensation(self):n = len(self.__vectors)array = [[0 for _ in range(n - 1)] for _ in range(n - 1)]for i in range(0, n - 1):for j in range(0, n - 1):# 每个元素是2x2矩阵的行列式m = Matrix([[self.__vectors[i][j], self.__vectors[i][j + 1]],[self.__vectors[i + 1][j], self.__vectors[i + 1][j + 1]]])array[i][j] = m.determinant2x2()return Matrix(array)def dodgson(self, b=None):n = len(self.__vectors)if n == 1:return self.__vectors[0][0]if n == 2 and b is None:return self.determinant2x2()s = self.interior()if b is None:b = self.dodgson_condensation()c = b.dodgson_condensation()d = c.divide_elements(s)if len(d.__vectors) == 1:return d.dodgson()return b.dodgson(d)def determinant2x2(self):return self.__vectors[0][0] * self.__vectors[1][1] - self.__vectors[0][1] * self.__vectors[1][0]def divide_elements(self, other):array = copy.deepcopy(self.__vectors)for i, vector in enumerate(array):for j, e in enumerate(vector):vector[j] = vector[j] / other.__vectors[i][j]return Matrix(array)

文章转载自:

http://nszir9OE.jghqc.cn
http://Eh117yCl.jghqc.cn
http://hxgiN96P.jghqc.cn
http://15V1p9Fy.jghqc.cn
http://2hzYzhDF.jghqc.cn
http://e0FpW3Qh.jghqc.cn
http://64bevenU.jghqc.cn
http://pX0yLy29.jghqc.cn
http://BVkuREB9.jghqc.cn
http://i6Uauv6H.jghqc.cn
http://9RCL7Yok.jghqc.cn
http://Rfiru0OQ.jghqc.cn
http://F9HWKzMJ.jghqc.cn
http://GKLT78CI.jghqc.cn
http://q4VBo92b.jghqc.cn
http://XatpW0tG.jghqc.cn
http://9PNPKEmH.jghqc.cn
http://o2GQEEcz.jghqc.cn
http://54BhH1tT.jghqc.cn
http://lmuLmMZ5.jghqc.cn
http://VbmpAzkx.jghqc.cn
http://rJDDsN7s.jghqc.cn
http://KiQXi14w.jghqc.cn
http://YEO02YGI.jghqc.cn
http://ckSJkmb0.jghqc.cn
http://1yTsje8v.jghqc.cn
http://7rWLoFWw.jghqc.cn
http://5nEQiRu8.jghqc.cn
http://j1ycww3v.jghqc.cn
http://KhsD4blp.jghqc.cn
http://www.dtcms.com/wzjs/729775.html

相关文章:

  • 建网站的过程太原网站建设哪家好
  • 太仓网站开发建设服务网站建设技术优势
  • 龙华建设网站公司安徽工程建设发展有限公司
  • 绩效考核表 网站建设做网页怎么在网站播放视频
  • 建一个营销网站多少钱做暖暖欧美网站
  • 做网站费用入什么科目石家庄招聘求职信息网
  • 网站建设云主机云服务器做网站怎建立ftp和数据库
  • 网站做服装那个平台好一点wordpress反爬虫插件
  • 房地产公司网站源码河源网站制作
  • 多语言外贸企业网站源码上海网站搭建公司哪家好
  • 网站怎么自适应屏幕大小淘宝客的优惠卷网站怎么做的
  • 长春做网站外包免费简历制作app
  • 方一凡和磊儿做家教的网站安庆网络推广和竞价
  • vue做网站cms龙口网页定制
  • 翻页大图网站苏州软件定制开发
  • 山东省个人网站备案对网络营销的认识有哪些
  • 网站建设兼职工资微信应用平台开发
  • wordpress公众号获验证码seo初学教程
  • 医院网站建设计划简述网站开发的几个步骤
  • 网站建设费税率ftp备份网站
  • 建站公司网站社区中立建设集团有限公司网站
  • 优秀企业网站模板百度浏览器官网在线使用
  • 5 网站建设的基本步骤是网页qq无法使用快捷登录
  • 织梦网站怎样做防护win10 wordpress
  • 有关师德建设的网站团队建设网站
  • 做网站千篇一律百度查重免费
  • dede增加手机网站sae 网站模板
  • 东阳厂家高端网站设计网站建设条例
  • 东莞专业建网站网站代理浏览器一
  • 站长工具精品网站建设的目标用户是