python算法

# 二分算法查找 时间复制度log(n)

def binary_search(list,item):

    row = 0

    high = len(list)-1

    while row <= high:
        mid = int((row + high) / 2)

        print('mid'+str(mid))

        guess = list[mid]

        if item == guess:
            return mid

        if item < guess:
            high = mid - 1

        else:
            row = mid + 1

    return None


if __name__ == '__main__':

    res = binary_search([1,3,4,5,7,9],4)

    print(res)
# 选择排序 时间复杂度(O(n*n))

def find_smallest(arr):
    smallest_idx = 0

    smallest = arr[smallest_idx]

    for i in range(len(arr)):

        if arr[i] < smallest:

            smallest_idx = i

            smallest = arr[smallest_idx]


    return  smallest


def section_sort(arr):

    new_arr = []

    for i in range(len(arr)):

        smallest =  find_smallest(arr)

        arr.remove(smallest)

        new_arr.append(smallest)


    print(new_arr)



if __name__ == '__main__':

    section_sort([1,5,3,9])

# 快速排序  时间复杂度:O(nlog(n)) 分而治之

def quick_sort(arr):

    if len(arr) < 2:
        return arr

    else:
        pivot = arr[0]

        less = [i for i in arr[1:] if i <= pivot]

        greater = [i for i in arr[1:] if i> pivot]

        return quick_sort(less) + [pivot] +quick_sort(greater)


if __name__ == '__main__':

    new_arr = quick_sort([1,6,4,3])

    print(new_arr)


#单向链表

#在python当中,所有的变量都是引用,也就是指针; a = 10,表示a 这个引用指向10这块内存;既然a 是引用,也可以去指向其他类型,如
# a= 'hello'

#在其他语言比如c语言当中,int a = 10;这个a 是10这个内存的别名;注意别名不是地址,比如我叫方煜逵,我的别名叫小方,但是我的地址是在员村XXX,你可以到员村XXX这个地址找到我,
#但是你到小方这个地址找到我,显然很扯!所以别名说的还是10这块内存;故这块内存是int类型,就无法在存其他了类型了;当然c语言引入指针类型int *b 来指向10这块内存

class SingleNode(object):

    def __init__(self,item):
        """单链表的结点"""

        # _item存放数据元素
        self.item = item
        # _next是下一个节点的标识
        self.next = None


#单链表的实现
class SingleLinkList(object):

    def __init__(self,head = None):

        self.__head = head

    def is_empty(self):
        """判断链表是否为空"""
        return self.__head == None

    def length(self):
        """链表长度"""
        # cur初始时指向头节点
        cur = self.__head
        count = 0
        # 尾节点指向None,当未到达尾部时
        while cur != None:
            count += 1
            # 将cur后移一个节点
            cur = cur.next
        return count

    def travel(self):
        """遍历链表"""
        cur = self.__head
        while cur != None:
            print(cur.item,end=' ')
            cur = cur.next
        print('')

    # 尾部添加元素
    def append(self,item):
        """尾部添加元素"""

        node = SingleNode(item)

        # 先判断链表是否为空,若是空链表,则将_head指向新节点
        if self.is_empty():
            self.__head = node
        # 若不为空,则找到尾部,将尾节点的next指向新节点
        else:
            cur = self.__head

            while cur.next != None:
                cur = cur.next
            cur.next = node
    #头部添加元素
    def add(self,item):
        """头部添加元素"""
        node = SingleNode(item)
        node.next = self.__head
        self.__head = node

    def insert(self, pos, item):

        if pos <= 0:
            self.add(item)
        elif pos >=  self.length()-1:
            self.append(item)
        else:
            node = SingleNode(item)

            pre_cur = self.__head

            cur_pos = 0

            while cur_pos < pos-1:
                pre_cur = pre_cur.next

                cur_pos += 1

            node.next = pre_cur.next

            pre_cur.next = node

    def search(self, item):
        """链表查找节点是否存在,并返回True或者False"""

        cur = self.__head

        while cur!= None:
            if item == cur.item:
                return True
            else:
                cur = cur.next

        return False

    def remove(self, item):
        """删除节点"""

        cur = self.__head

        pre = None
        
        while cur!= None:
            if item == cur.item:
                # 如果第一个就是删除的节点
                if cur == self.__head:
                    # 将头指针指向头节点的后一个节点
                    self.__head = cur.next
                    cur = self.__head
                else:
                    pre.next = cur.next
                    pre = cur
                    cur = cur.next

            else:

                pre = cur

                cur = cur.next


if __name__ == '__main__':
     l = SingleLinkList()
     l.append(1)
     l.append(2)

     l.append(3)
     l.append(4)


     l.append(5)
     l.append(6)

     l.travel()



#单向循环链表

class SingleNode(object):

    def __init__(self,item):
        """单链表的结点"""

        # _item存放数据元素
        self.item = item
        # _next是下一个节点的标识
        self.next = None


#单链表的实现
class SingleSycLinkList(object):

    def __init__(self,head = None):

        if head:
            self.__head = head
            head.next = self.__head
        else:
            self.__head = None

    def is_empty(self):
        """判断链表是否为空"""
        return self.__head == None

    def length(self):
        """链表长度"""
        # cur初始时指向头节点
        cur = self.__head
        count = 1
        # 尾节点指向None,当未到达尾部时
        while cur.next != self.__head:
            count += 1
            # 将cur后移一个节点
            cur = cur.next
        return count

    def travel(self):
        """遍历链表"""
        if self.is_empty():
            return
        cur = self.__head

        while cur.next != self.__head:
            print(cur.item,end=' ')
            cur = cur.next
        print(cur.item, end=' ')

    # 尾部添加元素
    def append(self,item):
        """尾部添加元素"""

        node = SingleNode(item)

        # 先判断链表是否为空,若是空链表,则将_head指向新节点
        if self.is_empty():
            self.__head = node
            node.next = self.__head
        # 若不为空,则找到尾部,将尾节点的next指向新节点
        else:
            cur = self.__head

            while cur.next != self.__head:
                cur = cur.next
            cur.next = node
            node.next = self.__head
    #头部添加元素
    def add(self,item):
        """头部添加元素"""

        node = SingleNode(item)

        if self.is_empty():
            self.append(item)
            return

        cur = self.__head
        while cur.next != self.__head:
            cur = cur.next

        node.next = self.__head

        cur.next = node

        self.__head = node

    def insert(self, pos, item):

        if pos <= 0:
            self.add(item)
        elif pos >=  self.length()-1:
            self.append(item)
        else:
            node = SingleNode(item)

            pre_cur = self.__head

            cur_pos = 0

            while cur_pos < pos-1:
                pre_cur = pre_cur.next

                cur_pos += 1

            node.next = pre_cur.next

            pre_cur.next = node

    def search(self, item):
        """链表查找节点是否存在,并返回True或者False"""
        if self.is_empty():
            return False

        cur = self.__head

        while cur.next!= self.__head:
            if item == cur.item:
                return True
            else:
                cur = cur.next
        if cur.item == item:
            return True
        return False

    def remove(self, item):
        """删除节点"""

        if self.is_empty():
            return

        cur = self.__head

        pre = None



        while cur.next!= self.__head:
            if item == cur.item:
                # 如果第一个就是删除的节点
                if cur == self.__head:
                    # 将头指针指向头节点的后一个节点
                    real = self.__head
                    while real.next != self.__head:
                        real = real.next

                    real.next = cur.next

                    self.__head = cur.next

                else:
                    pre.next = cur.next
                    pre = cur
                    cur = cur.next

            else:

                pre = cur

                cur = cur.next

        # real = self.__head
        # while real.next != self.__head:
        #     real = real.next
        if item == cur.item:
            pre.next = self.__head





if __name__ == '__main__':
     l = SingleSycLinkList()
     l.append(1)
     # l.append(2)
     # l.append(3)

     # #
     # l.add(0)
     # l.insert(1,2)
     # l.append(4)
     #
     #
     # l.append(5)
     # l.append(6)

     l.remove(1)



     l.travel()

#双向链表

class Node(object):

    def __init__(self,item):
        self.item = item
        self.pre = None
        self.next = None


class DoubleLinkList(object):

    def __init__(self,node = None):
        self.__head = node

    def is_empty(self):
        """链表是否为空"""
        return self.__head == None

    def length(self):
        """链表长度"""
        cur = self.__head
        count = 0
        while cur != None:
            cur = cur.next
            count += 1
        return count

    def travel(self):
        """遍历链表"""
        cur = self.__head
        while cur!= None:
            print(cur.item,end=' ')
            cur = cur.next

        print('')

    def append(self,item):
        """链表尾部添加"""
        node = Node(item)
        if self.is_empty():
            self.__head = node

        else:
            cur = self.__head
            while cur.next != None:
                cur = cur.next
            cur.next = node
            node.pre = cur

    def add(self, item):
        """链表头部添加"""
        node = Node(item)
        if self.is_empty():
            self.__head = node

        else:
            cur = self.__head
            node.next = cur
            cur.pre = node
            self.__head = node

    def insert(self,pos, item):
        """指定位置添加"""
        node = Node(item)
        if pos <=0:
            self.add(item)
        elif pos >= self.length()-1:
            self.append(item)
        else:
            cur = self.__head
            count = 0
            while count < pos:
                cur = cur.next
                count += 1
            cur.pre.next = node

            cur.pre = node

            node = cur.pre

            node.next = cur

    def search(self,item):
        """查找节点是否存在"""
        cur = self.__head
        while cur!=None:
            if cur.item == item:
                return True
            cur = cur.next
        return False

    def remove(self,item):
        """删除节点"""
        if self.is_empty():
            return
        else:
            cur = self.__head

            while cur != None:
                if cur.item == item:
                    node_pre = cur.pre
                    node_next = cur.next
                    #当删除为首结点
                    if cur == self.__head:
                        self.__head = node_next
                        node_next.pre = None
                    # 当删除为尾结点
                    elif node_next == None:
                        cur.pre.next = None

                    else:
                        node_pre.next = node_next
                        node_next.pre = node_pre

                cur = cur.next


if __name__ == '__main__':
    dll = DoubleLinkList()
    dll.append(2)
    dll.append(3)
    dll.append(4)
    dll.append(5)
    dll.add(1)
    dll.insert(2,4)
    dll.remove(1)
    dll.travel()



最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351