数学之美Aha数学数学储蓄罐

<<数学之美>> part5

2017-01-19  本文已影响302人  NemoHo

摘要: [图论] [网络爬虫] [图的遍历]

图论

说到图论,必须要提的就是KonigsBerg七桥问题,简单说就是哥尼斯堡这个地方的有四块独立的区域,由七座桥相互连接,如下图:

哥尼斯堡七桥问题

目标是从任意一个点A,B,C,D中的一个出发,不重复的走遍所有的路,并且回到原点,为了验证这个确实是不可能的我们采用递归遍历的方式穷举所有可能,下面是python代码(data表示每个节点可以到达的其他节点,以及与其他节点的连接路线数,因此所有数字加起来是总路线数的两倍,如果需要修改数据验证的话,记得每次都要修改两个地方哦,*例如:如果想把A到B的路线修改为5条,那么同时也要把B到A的修改为5条才行):

# -*- coding:utf8 -*-
#filename:konigsBerg.py
#version:1.0
#author: NemoHo
import sys

data={
#'A':{'B':2,'D':1},
#'B':{'A':2,'C':2,'D':1},
#'C':{'B':2,'D':1},
#'D':{'A':1,'B':1,'C':1}
'A':{'B':1,'D':4},
'B':{'A':1,'C':2,'D':2},
'C':{'B':2,'D':2},
'D':{'A':4,'B':2,'C':2}
}

def check_win(first,cur,data):
    if first != cur:
        return False
    for ch in data:
        for ch_sub in data[ch]:
            if data[ch][ch_sub] > 0:
                return False
    print "===============unbeliverb you win!===================="
    sys.exit(0)
    return True

def check_no_way(ch,data):
    can_go = data[ch]
    for ch in can_go:
        if can_go[ch] > 0:
            return False
    print "no way can go!"
    return True

def konigsberg(first,cur,data):
    new_data = {}
    for key in data:
        new_data[key] = {}
        for key_sub in data[key]:
            new_data[key][key_sub] = data[key][key_sub]
    print "cur pos : %s" % cur
    if check_win(first,cur,new_data) or check_no_way(cur,new_data):
        return
    can_go = new_data[cur]
    for ch_sub in can_go:
        if can_go[ch_sub] > 0:
            can_go[ch_sub]-=1
            new_data[ch_sub][cur]-=1
            konigsberg(first,ch_sub,new_data)
            can_go[ch_sub]+=1
            new_data[ch_sub][cur]+=1

if __name__ == '__main__':
    for ch in data:
        konigsberg(ch,ch,data)
        print "---------------------------"

当data中存在奇数,也就是说连接到某个地方的路线为奇数条时的运行结果图(结果太长,只截取了最后一段):


存在奇数时的运行结果图

当data中全是偶数时:


全是偶数时的运行结果图

这样我们起码从结果上来看发现结论是正确的,原理很简单:假设我们能够走遍所有的路并回到原点,那么说明进出原点的路线个数需要时偶数,也就是说最简单的讲AB两个点,我们从A出发,如果想要走遍AB以及所有路线并回到A,那么A到B的路线必须是进出成对出现的,也就是要满足偶数即可,如果是奇数的话在不重复的前提下,是不可能回到A的;

遍历方式

对于一张图,最重要的操作就是遍历,这里就涉及到两种遍历方式:

网络爬虫

之前写的一篇文章有提到,搜索引擎使用布尔代数的位运算的方式判断一篇文章是否满足某些关键字的条件来确定这篇文章是否应该被呈现给用户,当时主要是介绍了一下对关键字是否满足的判断,但是做这一切的前提是下载互联网上的网页到本地以及维护关键字表(这个就是网络爬虫的作用),这里我们重点介绍一下下载网页:

Thanks Doctor JunWu;

上一篇 下一篇

猜你喜欢

热点阅读