Algorithms,最全的Python算法仓库

​学习编程、学习Python最好的方式就是练习,哪怕是新手,只要不断地敲代码输出,肯定会有神效。

Python的练手项目很多,特别是Github上,建议不管新手、老司机都去看看。

Algorithms,最全的Python算法仓库

这里推荐给大家一个Gitthub上练习的项目,算法仓库-algorithms。

https://github.com/keon/algorithms

这里面集合众多核心算法的Python实现,比如排序、图计算、回溯、队列、流计算、堆、搜索、压缩等等。

Algorithms,最全的Python算法仓库

该仓库支持第三方库安装,在python中进行调用,非常方便。

首先使用pip进行安装:

pip3 install algorithms

登录后复制

然后导入相关模块进行调用,比如sort模块里的merge_sort归并排序算法。

from algorithms.sort import merge_sortif __name__ == "__main__":my_list = [1, 8, 3, 5, 6]my_list = merge_sort(my_list)print(my_list)

登录后复制

举几个常见的算法案例。

1. 排序算法-桶排序

def bucket_sort(arr):''' Bucket SortComplexity: O(n^2)The complexity is dominated by nextSort'''# The number of buckets and make bucketsnum_buckets = len(arr)buckets = [[] for bucket in range(num_buckets)]# Assign values into bucket_sortfor value in arr:index = value * num_buckets // (max(arr) + 1)buckets[index].append(value)# Sortsorted_list = []for i in range(num_buckets):sorted_list.extend(next_sort(buckets[i]))return sorted_listdef next_sort(arr):# We will use insertion sort here.for i in range(1, len(arr)):j = i - 1key = arr[i]while arr[j] > key and j >= 0:arr[j+1] = arr[j]j = j - 1arr[j + 1] = keyreturn arr

登录后复制

2. 机器学习-最近邻插值法

import mathdef distance(x,y):"""[summary]HELPER-FUNCTIONcalculates the (eulidean) distance between vector x and y.Arguments:x {[tuple]} -- [vector]y {[tuple]} -- [vector]"""assert len(x) == len(y), "The vector must have same length"result = ()sum = 0for i in range(len(x)):result += (x[i] -y[i],)for component in result:sum += component**2return math.sqrt(sum)def nearest_neighbor(x, tSet):"""[summary]Implements the nearest neighbor algorithmArguments:x {[tupel]} -- [vector]tSet {[dict]} -- [training set]Returns:[type] -- [result of the AND-function]"""assert isinstance(x, tuple) and isinstance(tSet, dict)current_key = ()min_d = float('inf')for key in tSet:d = distance(x, key)if d 

3. 字符串解码编码

# Implement the encode and decode methods.def encode(strs):"""Encodes a list of strings to a single string.:type strs: List[str]:rtype: str"""res = ''for string in strs.split():res += str(len(string)) + ":" + stringreturn resdef decode(s):"""Decodes a single string to a list of strings.:type s: str:rtype: List[str]"""strs = []i = 0while i 

4. 直方分布

def get_histogram(input_list: list) -> dict:"""Get histogram representation:param input_list: list with different and unordered values:return histogram: dict with histogram of input_list"""# Create dict to store histogramhistogram = {}# For each list value, add one to the respective histogram dict positionfor i in input_list:histogram[i] = histogram.get(i, 0) + 1return histogram

登录后复制

个人感觉这个仓库里的算法很齐全,适合做练习,小伙伴们可以试试。​

以上就是Algorithms,最全的Python算法仓库的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2234303.html

(0)
上一篇 2025年2月26日 17:29:59
下一篇 2025年2月26日 17:30:18

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Python怎么实现图的广度和深度优先路径搜索算法

    前言 图是一种抽象数据结构,本质和树结构是一样的。 图与树相比较,图具有封闭性,可以把树结构看成是图结构的前生。如果将兄弟节点或子节点之间的水平连接应用于树形结构,则可以创建一个图形结构。 树适合描述从上向下的一对多的数据结构,如公司的组织…

    2025年2月26日 编程技术
    000
  • Python中的行为验证码验证功能怎么实现

    验证类型概述 滑动拼图 创新行为式验证,轻松一滑完成拼图,体验极佳,秒速通过验证。简洁高效,在保障用户极致体验的同时,抵御机器风险。适用于追求用户体验的场景。 # 生成背景图  basemap1 = Image.open(bg).conve…

    编程技术 2025年2月26日
    200
  • Python机器学习类别特征的处理方法有哪些

    categorical features refer to characteristics with values that fall within a finite set of categories, such as occupatio…

    2025年2月26日
    200
  • Python的json标准库怎么用

    一、JSON基础概述 1、JSON是什么? JSON(全名:JavaScript Object Notation 对象表示法)是一种轻量级的文本数据交换格式,JSON的数据格式其实就是python里面的字典格式,里面可以包含方括号括起来的数…

    2025年2月26日 编程技术
    200
  • Python中的图像处理库有哪些?

    python已经成为了数据科学和人工智能领域的主流语言。因为python是一种易于学习的语言,它被普遍应用于各种领域,包括图像处理。 Python的图像处理库有很多。在本文中,我们将介绍一些主要的图像处理库以及如何使用它们。 OpenCV …

    编程技术 2025年2月26日
    200
  • Python中的持续集成是什么?

    python语言已经成为了现代软件开发中不可或缺的一部分,而其中持续集成(ci)则是高度集成及持续交付过程中的一部分,可以大大提升开发过程的效率和质量。ci的目的是通过将代码集成到一个公共的代码库,并持续运行自动化测试和静态分析工具,以最大…

    编程技术 2025年2月26日
    200
  • python架构PyNeuraLogic源码分析

    引言 展示神经符号编程的力量 1. 简介 在过去的几年里,我们看到了基于 Transformer 的模型的兴起,并在自然语言处理或计算机视觉等许多领域取得了成功的应用。在本文中,我们将探索一种简洁、可解释和可扩展的方式来表达深度学习模型,特…

    2025年2月26日 编程技术
    200
  • Python Sklearn中超实用的隐藏功能有哪些

    1 .covariance.EllipticEnvelope 通常,在我们的所处理的数据分布中有异常值是很常见的,并且许多算法都可以处理离群值,而 ellipticalenvelope 就是 sklearn 中直接内置的一个例子。该算法的优…

    2025年2月26日 编程技术
    200
  • Python进程间的通信方式是什么

    什么是进程的通信 这里举一个通信机制的例子:我们都很熟悉通信这个词,比如一个人想给他的女友打电话。一旦通话建立,便会形成一个隐式的队列(请注意这个术语)。此时这个人就会通过对话的方式不停的将信息告诉女友,而这个人的女友也是在倾听着。我认为在…

    2025年2月26日 编程技术
    200
  • Python中的有监督学习是什么?

    python中的有监督学习是什么? 在Python数据分析中,有监督学习算法在机器学习领域中占据重要位置。这种学习方式利用已知输入和输出来训练模型以预测未知输入的输出。简而言之,有监督学习是将样本数据中的输入变量和输出变量联系起来,并利用已…

    编程技术 2025年2月26日
    200

发表回复

登录后才能评论