Python实现七个基本算法的实例代码

yizhihongxing

下面是关于“Python实现七个基本算法的实例代码”的完整攻略。

1. 七个基本算法

七个基本法是指排序、查找、字符串、数组、表、树图这七个领域的基本算法。这些算法是计算机科学最基本的算法之一,也是Python开发者必须握的算法之一。

2. 算法实现

下面是使用Python实现七个基本算法的完整代码。

2.1 排序算法

2.1.1 冒泡排序

def bubble_sort(arr):
    n = len(arr)
    for i in range(n):
        for j in range(0, n-i-1):
            if arr[j] > arr[j+1]:
                arr[j], arr[j+1] = arr[j+1], arr[j]
    return arr

2.1.2 快速排序

def quick_sort(arr):
    if(arr) <= 1:
        return arr
    pivot = arr[len(arr) // 2]
    left = [x for x in arr if x < pivot]
    middle = [x for x in arr if x == pivot]
    right = [x for x in arr if x >]
    return quick_sort(left) + middle + quick_sort(right)

2.2 查找算法

2.2.1 二分查找

def binary_search(arr, x):
    low, high 0, len(arr) - 1
    while low <= high:
        mid = (low + high) // 2
        if arr[mid] < x:
            low = mid + 1
        elif arr[mid] > x:
            high = mid - 1
        else:
            return mid
    return -1

2.3 字符串算法

2.3.1 字符串反转

def reverse_string(s):
    return s[::-1]

2.4 数组算法

2.4.1 数组求和

def array_sum(arr):
    return sum(arr)

2.5 链表算法

2.5.1 链表反转

class ListNode:
    def __init__(self, val=0, next=None):
        self.val = val
        self.next = next

def reverse_list(head):
    prev = None
    curr = head
    while curr:
        next_node = curr.next
        curr.next = prev
        prev = curr
        curr = next_node
    return prev

2.6 树算法

2.6.1 二叉树遍历

class TreeNode:
    def __init__(self, val=0, left=None, right=None):
        self.val = val
        self.left = left        self.right = right

def inorder_traversal(root):
    if not root:
        return []
    return inorder_traversal(root.left) + [root.val] + inorder_traversal(root.right)

2.7 图算法

2.7.1 图遍历

from collections import deque

def bfs(graph, start):
    visited = set()
    queue = deque([start])
    while queue:
        vertex = queue.popleft()
        if vertex not in visited:
            visited.add(vertex)
            queue.extend(graph[vertex] - visited)
    return visited

3. 示例

下面是两个基本算法的示例,分别展示了冒泡排序和二分查找的实现。

3.1 冒排序示例

arr = [64, 34, 25, 12, 22, 11, 90]
sorted_arr = bubble_sort(arr)
print("Sorted array:", sorted_arr)

输出:

Sorted array: [11, 12, 22, 25, 34, 64, 90]

3.2 二分查找示例

arr = [2, 3, 4, 10, 40]
x = 10
result = binary_search(arr, x)
if result != -1:
    print("Element is present at index", str(result))
else:
    print("Element is not present in array")

输出:

Element is present at index 3

4. 总结

七个基本算法是计算机科学中最基本的算法之一,也是开发者必掌握的算法之一。在Python中,我们可以使用各种数据结构和算法来实现这些基本算法。在实际应用中,我们可以根据具体问题选择适当的算法来进行开发和实现。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Python实现七个基本算法的实例代码 - Python技术站

(0)
上一篇 2023年5月13日
下一篇 2023年5月13日

相关文章

  • Python 打印中文字符的三种方法

    下面是详细讲解Python打印中文字符的三种方法的完整攻略: 前言 在Python中,如果要打印中文字符,可能会遇到一些问题。这是因为Python默认使用的编码是ASCII,它不能直接表示中文字符。下面我们就来介绍一些解决此问题的方法。 方法一:在程序文件开头加入注释声明文件编码 在程序文件开头加入注释声明文件编码是一种简单易用的方法。 例如,如果在程序文件…

    python 2023年6月3日
    00
  • python的自变量选择(所有子集回归,后退法,逐步回归)

    自变量选择是指在建立回归模型时,选择哪些自变量对因变量的影响最大。常用的自变量选择方法包括所有子集回归、后退法和逐步回归。本文将详细介绍这三种方法的实现过程,并提供两个示例说明。 所有子集回归 所有子集回归是一种穷举法,它将所有可能的自变量组合都考虑到,并选择最优的组合。在Python中,我们可以使用mlxtend库中的ExhaustiveFeatureSe…

    python 2023年5月14日
    00
  • Python写的Discuz7.2版faq.php注入漏洞工具

    首先,需要明确的是,攻击是违法的行为,我们强烈反对任何形式的网络攻击行为。接下来,我们将讲解如何防范此类攻击,以保护网站的安全。 针对“Python写的Discuz7.2版faq.php注入漏洞工具”的攻击,我们可以采取以下措施: 1. 及时更新漏洞补丁 Discuz 7.2 版本中存在的漏洞已经被官方修复,网站管理员应该及时升级到最新的版本,并及时打补丁,…

    python 2023年6月3日
    00
  • ndarray数组的转置(transpose)和轴对换方式

    ndarray数组的转置是指将数组的维度重新排列,而轴对换是指根据指定的维度进行转置操作。在NumPy中,可以通过transpose和swapaxes方法进行转置和轴对换操作。 转置操作 转置操作可以使用ndarray的transpose方法进行,该方法可以接受一个由对应维度索引组成的tuple作为参数。如果不指定参数,transpose方法默认对所有轴进行…

    python 2023年6月5日
    00
  • python标准库之time模块的语法与简单使用

    下面是”python标准库之time模块的语法与简单使用”的完整攻略。 一、time模块简介 Python标准库中的time模块提供了一组处理时间的函数,常用于计算程序执行时间、时间戳转换以及获取当前时间等操作。 二、time模块的基本语法 引入time模块:import time 常用函数如下: time():返回当前时间的时间戳,单位为秒。 localt…

    python 2023年6月2日
    00
  • selenium python 实现基本自动化测试的示例代码

    实现基本自动化测试的示例代码有以下几个步骤: 安装selenium和webdriver Selenium是一个自动化测试工具,可以用它来模拟浏览器行为,webdriver是Selenium的一个子模块,负责与浏览器进行交互,并将用户的操作转换为命令。在Python下安装Selenium和WebDriver的方法如下: pip install selenium…

    python 2023年5月19日
    00
  • Python爬虫:url中带字典列表参数的编码转换方法

    当Python爬虫需要将字典或列表参数作为查询参数添加到URL链接中时,需要对其进行编码转换,否则在程序访问该链接时可能出现问题。以下是完整的攻略: 1. 理解URL的编码格式 URL编码格式指将URL链接中的特殊字符使用特定的编码方式进行转换,使得这些字符能够被顺利传递且不造成歧义。常见的URL编码方式为UTF-8编码方式。 例如,对于一个URL链接 ht…

    python 2023年5月31日
    00
  • 对python中dict和json的区别详解

    对 Python 中 dict 和 json 的区别详解 相同点 dict 和 json 都可以用来表示键值对。 dict 和 json 都可以使用相同的键或者值类型。 区别 1. 序列化和反序列化 dict 是 Python 内置的一种数据结构,可以直接使用 Python 的方法进行序列化和反序列化。比如: import json d = {‘a’: 1,…

    python 2023年5月13日
    00
合作推广
合作推广
分享本页
返回顶部