python机器学习手写算法系列——线性回归

2023-10-30

本系列另一篇文章《决策树》
https://blog.csdn.net/juwikuang/article/details/89333344

本文源代码:
https://github.com/juwikuang/machine_learning_step_by_step

最近我发现我之前写的一篇文章《一个公式告诉你为什么程序员要转算法工程师》
http://blog.csdn.net/juwikuang/article/details/73057194
有很多人访问。我想,很多程序员和我当初一样,想从程序员转算法工程师。

说说我当初为什么会想到升级成算法工程师。记得三年前,我还在印孚瑟斯(Infosys),我们的CFO非常自豪的宣布公司已经成功的让专科生的比例提高了,让本科生的比例降低了。我作为一个本科程序员,听了十分难受。当然,公司这样做是为了利润,也合理合法。换了我是CFO,我也会这样做,不过,我应该不会像他一样大声说。有些事,可以做,不能说。

后来,机缘巧合,我学习了机器学习,走上了算法工程师这条路。当时我学机器学习,是从吴恩达(Andrew Ng)的Coursera课程开始的。很多人和我一样,也是开了这门课,开始机器学习的。这门课挺好,可惜开发语言用了Octave,以至于我每次写作业,都很痛苦,因为我还要学Octave语言,而且这东西学了也没啥用。另外,这门课是英语的,只有少数人能看懂。

本文的目的,就是从最基本,最简单的机器学习算法讲起,手把手的教你实现这个算法。一边编程,一边就明白这个算法的原理了。我本人也是程序员转的算法工程师,我们的强项就是编程,弱项就是数学。我针对这个特点,专门做了以下教程。

言归正传。首先我们看看线性回归在整个机器学习里的位置。

从机器学习到线性回归

线性回归在整个机器学习

今天,我们只关注机器学习到线性回归这条线上的概念。别的以后再说。为了让大家听懂,我这次也不查维基百科了,直接按照自己的理解用大白话说,可能不是很严谨。

机器学习就是机器可以自己学习,而机器学习的方法就是利用现有的数据和算法,解出算法的参数。从而得到可以用的模型。

监督学习就是利用已有的数据(我们叫X,或者特征),和数据的标注(我们叫Y),找到x和y之间的对应关系,或者说是函数f。

回归分析是一种因变量为连续值得监督学习。

线性回归是一种x和y之间的关系为线性关系的回归分析。 y = a 1 x 1 + a 2 x 2 + b y=a_1x_1+a_2x_2+b y=a1x1+a2x2+b,这个叫线性关系。如果这里出现了 x 2 x^2 x2, l o g ( x ) log(x) log(x), s i n ( x ) sin(x) sin(x)之类的,那就不是线性关系了。

一元线性回归说的是,自变量x是一个纯量(scalar)。scalar类型的变量,是不可再分的。

我希望你能说明白这些概念的关系。不过,我自己也是花了很久才了解清楚的。如果你没听明白,也没关系。毕竟都是概念,没什么实际的例子,也很难理解。等你看完了本文,了解了一元线性回归。回过头来再看这些概念,就能更好的理解了。

问题

这里,我们的问题是,找出算法工程师和程序员之间的工资关系。这里直接给出北京,上海,杭州,深圳,广州的工资。

城市 x-程序员工资 y-算法工程师工资
北京 1.3854 2.1332
上海 1.2213 2.0162
杭州 1.1009 1.9138
深圳 1.0655 1.8621
广州 0.09503 1.8016

把他们用图打出来看看他们之间的关系。

程序员和算法工程师工资

由图可见,他们之间大致是一个线性关系,这时候,我们就可以试着用一元线性回归去拟合(fit)他们之间的关系。

数学模型

一元线性回归公式

以下是公式
y = a x + b + ε y=ax+b+ε y=ax+b+ε

y 为应变量 dependent variable
x 为自变量 independent variable
a 为斜率 coeffient
b 为截距 intercept
ε (读作epsilon)为误差,正态分布
线性回归的目标是,找到一组a和b,使得ε最小
y ^ = a x + b \hat{y}=ax+b y^=ax+b
ε = y − y ^ ε=y-\hat{y} ε=yy^

y ^ \hat{y} y^ 读作y hat,也有人读作y帽子。这里的帽子一般表示估计值,用来区别真实值y。

下图可以更好的帮助你理解。

一元线性回归
(图片来自互联网)

黑色的点为观测样本,即 y = a x + b + ε y=ax+b+ε y=ax+b+ε

x红色的线为回归线,即 y ^ = a x + b \hat{y}=ax+b y^=ax+b

x蓝色的线段为误差,即 ε = y − y ^ ε=y-\hat{y} ε=yy^

方差 - 损失函数 Cost Function

在机器学习中,很多时候,我们需要找到一个损失函数。有了损失函数,我们就可以经过不断地迭代,找到损失函数的全局或者局部最小值(或者最大值)。损失函数使得我们的问题转化成数学问题,从而可以用计算机求解。在线性回归中,我们用方差作为损失函数。我们的目标是使得方差最小。

下面的表格解释了什么是方差。

方差

其中SSE(Sum of Square Error)是总的方差,MSE(Mean Square Error)是方差的平均值。

而这里的损失函数,用的是0.5 * MSE。即:

J ( a , b ) = 1 2 n ∑ i = 0 n ( y i − y ^ i ) 2 J(a,b)=\frac{1}{2n}\sum_{i=0}^{n}(y_i−\hat{y}_i )^2 J(a,b)=2n1i=0n(yiy^i)2

记住,这里的损失函数是针对参数a和b的函数,y和 y ^ \hat{y} y^ 其实都是已知的。

优化方法 Optimization Function

有了损失函数,我们还需要一个方法,使得我们可以找到这个损失函数的最小值。机器学习把他叫做优化方法。这里的优化方法,就是算损失的方向。或者说,当我的参数变化的时候,我的损失是变大了还是变小了。如果a变大了,损失变小了。那么,说明a增大这个方向是正确的,我们可以朝着这个方向继续小幅度的前进。反之,就应该考虑往相反的方向试试看。因为每个参数(a和b)都是一维的,所以,所谓的方向,无非就是正负符号。

这里,我们需要用偏微分的方法,得到损失函数的变化量。即:

∂ J ∂ a = ∂ 1 2 n ∑ i = 0 n ( y i − y ^ i ) 2 ∂ a \frac{\partial J}{\partial a} = \frac{\partial \frac{1}{2n}\sum_{i=0}^{n}(y_i−\hat{y}_i )^2}{\partial a} aJ=a2n1i=0n(yiy^i)2
= 1 n ∑ i = 0 n ( y i − a x i − b ) ∂ ( y i − a x i − b ) ∂ a = \frac{1}{n}\sum_{i=0}^{n}(y_i-ax_i-b) \frac{\partial (y_i-ax_i-b)}{\partial a} =n1i=0n(yiaxib)a(yiaxib)
= 1 n ∑ i = 0 n ( y i − a x i − b ) ( − x i ) = \frac{1}{n}\sum_{i=0}^{n}(y_i-ax_i-b) (-x_i) =n1i=0n(yiaxib)(xi)
= 1 n ∑ i = 0 n x ( y ^ i − y i ) = \frac{1}{n}\sum_{i=0}^{n}x(\hat{y}_i-y_i) =n1i=0nx(y^iyi)

∂ J ∂ b = ∂ 1 2 n ∑ i = 0 n ( y i − y ^ i ) 2 ∂ a \frac{\partial J}{\partial b} = \frac{\partial \frac{1}{2n}\sum_{i=0}^{n}(y_i−\hat{y}_i )^2}{\partial a} bJ=a2n1i=0n(yiy^i)2
= 1 n ∑ i = 0 n ( y i − a x i − b ) ∂ ( y i − a x i − b ) ∂ b = \frac{1}{n}\sum_{i=0}^{n}(y_i-ax_i-b) \frac{\partial (y_i-ax_i-b)}{\partial b} =n1i=0n(yiaxib)b(yiaxib)
= 1 n ∑ i = 0 n ( y i − a x i − b ) ( − 1 ) = \frac{1}{n}\sum_{i=0}^{n}(y_i-ax_i-b) (-1) =n1i=0n(yiaxib)(1)
= 1 n ∑ i = 0 n ( y ^ i − y i ) = \frac{1}{n}\sum_{i=0}^{n}(\hat{y}_i-y_i) =n1i=0n(y^iyi)

如果你已经忘了微积分,你暂时可以不必纠结上面的公式,只要知道公式给出了损失函数的变化就可以了。伟大的python还提供了sympy,你可以用sympy做微积分。这部分我也放在附件代码里了,有兴趣的可以看一下。

之前说到,整过迭代过程是小幅度进行的。这里,就需要一个超参数来控制这个过程。这个超参数就是 α \alpha α,通常是0.01.

这时,我们就可以去更新a和b的值:
a = a − α ∂ J ∂ a a = a - \alpha \frac{\partial J}{\partial a} a=aαaJ
b = b − α ∂ J ∂ b b = b - \alpha \frac{\partial J}{\partial b} b=bαbJ

到这里,在你继续往下读之前,你先自己考虑一下,为什么这里是负号?

你考虑好了么,如果你考虑好了,我就公布答案了。

本身 ∂ J ∂ a \frac{\partial J}{\partial a} aJ ∂ J ∂ b \frac{\partial J}{\partial b} bJ 是损失函数的变化量。如果损失函数随着a变大了,即 ∂ J ∂ a \frac{\partial J}{\partial a} aJ 为正。说明a的增大会导致损失函数的增大。那么是不是说,a的减小会使得损失函数减小呢?而我们的目标是使得J最小,所以,这个时候,我们的a要减小一点点。

损失的方向
(图片来自互联网)

算法步骤

  1. a和b的起始值设置为零
  2. 通过模型 y ^ = a x + b \hat{y}=ax+b y^=ax+b,我们可以算出 y ^ \hat{y} y^
  3. 有了 y ^ \hat{y} y^,就可以用优化方法算去更新参数
  4. 重复2和3,直到找到J的最小值

流程图如下:

Created with Raphaël 2.2.0 开始 a=0, b=0 计算模型y_hat=ax+b 计算a和b的微分 更新a和b 找到损失函数的最小值 结束 yes no

下图解释了模型,损失函数和优化方法之间的关系。

模型,损失函数和优化方法之间的关系

Python 实现

理论部分先告一段落,我们现在开始写代码,实现一元线性回归。

首先是模型,这个很简单:

def model(a, b, x):
    return a*x + b

接着,是损失函数:

def cost_function(a, b, x, y):
    n = 5
    return 0.5/n * (np.square(y-a*x-b)).sum()

最后,是优化函数:

def optimize(a,b,x,y):
    n = 5
    alpha = 1e-1
    y_hat = model(a,b,x)
    da = (1.0/n) * ((y_hat-y)*x).sum()
    db = (1.0/n) * ((y_hat-y).sum())
    a = a - alpha*da
    b = b - alpha*db
    return a, b

以上三个函数中a和b是标量(scalar value),x和y是向量(vector)
至此,一元线性回归的主要部分就完成了。一共才14行代码,是不是很简单。

训练模型

有了模型,损失函数,优化函数,我们就可以训练模型了。具体过程请见附件代码。

这里给出分别训练1次,再训练5次,再训练10次,再训练100,再训练10000次的模型。

1次

5次

10次

100次

10000次

从上面几幅图,我们可以看到,随着训练次数的增加,回归线越来越接近样本了。我们自己写的线性回归比较简单,我只能目测,凭直觉感觉损失函数已经达到了最小值,我们就停在10000次吧。

看得再多,不如自己动手。阅读下一章节之前,请自己实现一元线性回归。

这里有现成的代码,供你参考。

http://download.csdn.net/download/juwikuang/10050886

模型评价

在机器学习中,模型的好坏是有标准的。在回归模型中,我们用 R 2 R^2 R2 来评价模型。公式:
R 2 = S S R / S S T R^2=SSR/SST R2=SSR/SST
其中
S S R = ∑ i = 0 n ( y ^ i − y ˉ ) SSR=\sum_{i=0}^{n}(\hat{y}_i-\bar{y}) SSR=i=0n(y^iyˉ)
S S T = ∑ i = 0 n ( y i − y ˉ ) SST=\sum_{i=0}^{n}(y_i-\bar{y}) SST=i=0n(yiyˉ)
y ˉ \bar{y} yˉ 读作y bar,是y的平均值。
可以证明 S S T = S S R + S S E SST=SSR+SSE SST=SSR+SSE,证明过程又会涉及到期望等概念,我们这里不展开了。

好了,现在你应该回到代码中去计算 R 2 R^2 R2 了。

用scikit-learn训练和评价模型

平时在工作中,我们不可能自己去写回归模型,最常用的第三方工具是scikit-learn。
其官网是:
http://scikit-learn.org/

以下是ipython代码。

import numpy as np
from sklearn.linear_model import LinearRegression
import matplotlib.pyplot as plt
%matplotlib inline

x = [13854,12213,11009,10655,9503] #程序员工资,顺序为北京,上海,杭州,深圳,广州
x = np.reshape(x,newshape=(5,1)) / 10000.0
y =  [21332, 20162, 19138, 18621, 18016] #算法工程师,顺序和上面一致
y = np.reshape(y,newshape=(5,1)) / 10000.0
# 调用模型
lr = LinearRegression()
# 训练模型
lr.fit(x,y)
# 计算R平方
print lr.score(x,y)
# 计算y_hat
y_hat = lr.predict(x)
# 打印出图
plt.scatter(x,y)
plt.plot(x, y_hat)
plt.show()

恭喜你,看完了本文,也学会了一元线性回归。如果对你有帮助,请给我一个赞。你的支持和鼓励是我继续写下去的动力。

如果有疑问,请下面留言。

python机器学习手写算法系列

完整源代码:

https://github.com/juwikuang/machine_learning_step_by_step

欢迎阅读本系列其他文章:

《python机器学习手写算法系列——线性回归》

《python机器学习手写算法系列——逻辑回归》

《python机器学习手写算法系列——决策树》

《python机器学习手写算法系列——kmeans聚类》

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

python机器学习手写算法系列——线性回归 的相关文章

  • 围绕 readline 构建的 python 批处理的触发器选项卡完成

    背景 我有一个 python 程序 它导入并使用 readline 模块来构建自制的命令行界面 我有第二个 python 程序 围绕 Bottle 一个 Web 微框架构建 充当该 CLI 的前端 第二个 python 程序向第一个程序打开
  • 如何迭代按值排序的 Python 字典?

    我有一本字典 比如 a 6 b 1 c 2 我想迭代一下by value 不是通过键 换句话说 b 1 c 2 a 6 最直接的方法是什么 sorted dictionary items key lambda x x 1 对于那些讨厌 la
  • 将数据帧行转换为字典

    我有像下面的示例数据这样的数据帧 我正在尝试将数据帧中的一行转换为类似于下面所需输出的字典 但是当我使用 to dict 时 我得到了索引和列值 有谁知道如何将行转换为像所需输出那样的字典 任何提示都非常感激 Sample data pri
  • Pandas 中允许重复列

    我将一个大的 CSV 包含股票财务数据 文件分割成更小的块 CSV 文件的格式不同 像 Excel 数据透视表之类的东西 第一列的前几行包含一些标题 公司名称 ID 等在以下列中重复 因为一家公司有多个属性 而不是一家公司只有一栏 在前几行
  • 填充两个函数之间的区域

    import matplotlib pyplot as plt import numpy as np def domain x np arange 0 10 0 001 f1 lambda x 2 x x 2 0 5 plt plot x
  • 忽略 Mercurial hook 中的某些 Mercurial 命令

    我有一个像这样的善变钩子 hooks pretxncommit myhook python path to file myhook 代码如下所示 def myhook ui repo kwargs do some stuff 但在我的例子中
  • Pandas 数据帧到 numpy 数组 [重复]

    这个问题在这里已经有答案了 我对 Python 很陌生 经验也很少 我已经设法通过复制 粘贴和替换我拥有的数据来使一些代码正常工作 但是我一直在寻找如何从数据框中选择数据 但无法理解这些示例并替换我自己的数据 总体目标 如果有人真的可以帮助
  • 如何通过在 Python 3.x 上按键来启动和中断循环

    我有这段代码 当按下 P 键时会中断循环 但除非我按下非 P 键 否则循环不会工作 def main openGame while True purchase imageGrab if a sum gt 1200 fleaButton ti
  • 使用鼻子获取设置中当前测试的名称

    我目前正在使用鼻子编写一些功能测试 我正在测试的库操作目录结构 为了获得可重现的结果 我存储了一个测试目录结构的模板 并在执行测试之前创建该模板的副本 我在测试中执行此操作 setup功能 这确保了我在测试开始时始终具有明确定义的状态 现在
  • 如何从Python中的字符串中提取变量名称和值

    我有一根绳子 data var1 id 12345 name John White python中有没有办法将var1提取为python变量 更具体地说 我对字典变量感兴趣 这样我就可以获得变量的值 id和name python 这是由提供
  • 如何设置 Celery 来调用自定义工作器初始化?

    我对 Celery 很陌生 我一直在尝试设置一个具有 2 个独立队列的项目 一个用于计算 另一个用于执行 到目前为止 一切都很好 我的问题是执行队列中的工作人员需要实例化一个具有唯一 object id 的类 每个工作人员一个 id 我想知
  • 首先对列表中最长的项目进行排序

    我正在使用 lambda 来修改排序的行为 sorted list key lambda item item lower len item 对包含元素的列表进行排序A1 A2 A3 A B1 B2 B3 B 结果是A A1 A2 A3 B
  • Pandas 根据 diff 列形成簇

    我正在尝试使用 Pandas 根据表示时间 以秒为单位 的列中的差异来消除数据框中的一些接近重复项 例如 import pandas as pd numpy as np df pd DataFrame 1200 1201 1233 1555
  • 创建嵌套字典单行

    您好 我有三个列表 我想使用一行创建一个三级嵌套字典 i e l1 a b l2 1 2 3 l3 d e 我想创建以下嵌套字典 nd a 1 d 0 e 0 2 d 0 e 0 3 d 0 e 0 b a 1 d 0 e 0 2 d 0
  • mac osx 10.8 上的初学者 python

    我正在学习编程 并且一直在使用 Ruby 和 ROR 但我觉得我更喜欢 Python 语言来学习编程 虽然我看到了 Ruby 和 Rails 的优点 但我觉得我需要一种更容易学习编程概念的语言 因此是 Python 但是 我似乎找不到适用于
  • 使用 PyTorch 分布式 NCCL 连接失败

    我正在尝试使用 torch distributed 将 PyTorch 张量从一台机器发送到另一台机器 dist init process group 函数正常工作 但是 dist broadcast 函数中出现连接失败 这是我在节点 0
  • 当鼠标悬停在上面时,intellisense vscode 不显示参数或文档

    我正在尝试将整个工作流程从 Eclipse 和 Jupyter Notebook 迁移到 VS Code 我安装了 python 扩展 它应该带有 Intellisense 但它只是部分更糟糕 我在输入句点后收到建议 但当将鼠标悬停在其上方
  • 在Python中按属性获取对象列表中的索引

    我有具有属性 id 的对象列表 我想找到具有特定 id 的对象的索引 我写了这样的东西 index 1 for i in range len my list if my list i id specific id index i break
  • 如何读取Python字节码?

    我很难理解 Python 的字节码及其dis module import dis def func x 1 dis dis func 上述代码在解释器中输入时会产生以下输出 0 LOAD CONST 1 1 3 STORE FAST 0 x
  • Elastic Beanstalk 中的 enum34 问题

    我正在尝试在 Elastic Beanstalk 中设置 django 环境 当我尝试通过requirements txt 文件安装时 我遇到了python3 6 问题 File opt python run venv bin pip li

随机推荐

  • 【React】React路由概念

    文章目录 1 路由概述 1 1 后端路由 1 2 前端路由 2 SPA 3 前端路由两种模式 3 1 hash模式 3 2 history模式 1 路由概述 路由 简单来说 路由是根据不同的url地址展示不同的内容或页面 一个路由就是一个映
  • echarts x坐标文字换行显示

    xAxis type category data axisLabel 坐标轴刻度标签的相关设置 interval 0 显示一竖条 formatter function value return value split join n 一行显示
  • 给定一个数组nums,编写一个函数将所有0移动到数组的末尾,同时保持非零元素的相对顺序。

    给定一个数组nums 编写一个函数将所有0移动到数组的末尾 同时保持非零元素的相对顺序 要求 1 必须在原数组上操作 不能拷贝额外的数组 2 尽量减少操作次数 3 注意时间空间复杂度 输入 0 1 0 3 12 输出 1 3 12 0 0
  • Linux文件权限分段说明

    Linux文件权限分段说明 Linux中的文件属性权限描述一共10位长度 并分为四段 如 rwxrwx 一共十位 第一段占一位 代表文件类型 其中例子中的 代表普通文件 其余的表示还有 文件类型部分 文件 d 文件夹 l 链接文件 可以理解
  • nginx解析PHP特卡,nginx解析PHP程序报错的解决方案

    root server 2 log tail f nginx error log 2019 07 31 01 51 02 error 26151 0 52 FastCGI sent in stderr Primary script unkn
  • Springboot 文件处理导入导出

    简单记录下使用Springboot进行文件与后端交互 excel前台导出等内容 这里用到了 elelemt ui HTML vue Springboot框架 一 后台导入 HTML
  • VBS加载微软网页控件webview2(Edge-Chromium谷歌内核)

    VBS加载微软网页控件webview2 Edge Chromium谷歌内核 VBA加载Webview2浏览器内核 代替了ie的webbrowser控件 效果类似 资源 VBS加载webview2控件代替ie的webbrowser Edge
  • Oracle UTL_HTTP(收集汇总有用资料)

    From Oracle The UTL HTTP package makes Hypertext Transfer Protocol HTTP callouts from SQL and PL SQL You can use it to a
  • shell脚本中任意输入三个数,输出最大值

    Linux下用shell脚本任意输入三个数 输出最大值 bin bash read p 请输入第一个数 n1 read p 请输入第二个数 n2 read p 请输入第三个数 n3 max n1 if n2 gt max then max
  • 同态加密简介

    同态加密概述 基本概念 同态加密 Homomorphic Encryption HE 指将原始数据经过同态加密后 对密文进行特定的运算 得到的密文计算结果在进行同态解密后的得到的明文等价于原始明文数据直接进行相同计算所得到的数据结果 历史与
  • 快速加入Health Kit,一文了解审核流程

    HUAWEI Health Kit是为华为生态应用打造的基于华为帐号和用户授权的运动健康数据开放平台 在获取用户授权后 开发者可以使用Health Kit提供的开放能力获取运动健康数据 基于多种类型数据构建运动健康领域应用与服务 为用户打造
  • axios实现本地缓存

    import axios from axios 线上数据库 axios defaults baseURL XXXXXXXXXXXXX 测试数据库 axios defaults baseURL http 192 168 1 25 8080 a
  • QMap和std::map的遍历

    两种遍历方式都使用迭代器 1QMap使用Iterator key 和Iterator value 方法获取第一个或第二个元素的值 而std map使用Iterator gt first Iterator gt second 来获取第一个或第
  • 为什么把系统带宽定义为-3dB?

    原文来自公众号 工程师看海 为什么把系统带宽定义为 3dB 对于我们常说的电路带宽或系统带宽 指的是增益为 3dB时的频率点 为什么选 3dB呢 对于带宽我们可以粗暴的理解为 系统的有效频率范围小于 3dB时的频点 简单来说 比如一个系统
  • 微信小程序练手实战:前端+后端(Java)

    1 前言 现在微信小程序越来越火了 相信不少人都通过各种途径学习过微信小程序或者尝试开发 作者就是曾经由于兴趣了解开发过微信小程序 最终自己的毕业设计也是开发一个微信小程序 所以现在用这篇博客记录我之前开发的一些经验和一些心得吧 2 主要内
  • 【Unity】一键切换是否允许#if UNITY_EDITOR条件编译生效

    在项目中经常会条件编译的方式来让编译器环境和非编译器环境跑不同的代码 但这种方式会让非编译器环境的代码测试变得十分不方便 UNITY EDITOR也是Unity预定义的宏 不能直接在PlayerSettings里面增加或删除 if UNIT
  • github实现在线运行程序

    复制定时任务代码进来 name weixin on workflow dispatch schedule 代表国际标准时间4点0分 北京时间需要 8小时 代表北京时间中午12点运行 cron 30 23 jobs 将工作流程中运行的所有作业
  • Vue h5 调用微信扫码接口

    需求 调用微信扫码接口 然后获取扫码返回结果的url中的参数 携参跳转到其他页面 1 安装微信js sdk 通过yarn安装 yarn add weixin js sdk 通过npm安装 npm i weixin js sdk 2 引用 i
  • 150.逆波兰表达式求值

    目录 一 题目 二 分析 代码 三 中缀表达式转后缀表达式 一 题目 150 逆波兰表达式求值 力扣 LeetCode 二 分析 代码 class Solution public int evalRPN vector
  • python机器学习手写算法系列——线性回归

    本系列另一篇文章 决策树 https blog csdn net juwikuang article details 89333344 本文源代码 https github com juwikuang machine learning st