Google资深工程师深度讲解Go语言-函数式编程(六)

Google资深工程师深度讲解Go语言-函数式编程(六)

大家好,又见面了,我是全栈君。

一.函数式编程

1.函数与闭包

函数式编程vc函数指针

  • 函数是一等公民:参数,边临,返回值都可以是函数
  • 高阶函数
  • 函数->闭包

“正统”函数式编程

  • 不可变性:不能有状态,只有常量和函数
  • 函数只能有一个参数

Google资深工程师深度讲解Go语言-函数式编程(六)

package main

import "fmt"

func adder() func(int) int {
	sum := 0
	return func(v int) int {
		sum += v
		return sum
	}
}

func main() {
	a := adder()
	for i := 0; i < 10; i++ {
		fmt.Printf("0+1+...%d=%d\n",i,a(i))
	}
}
package main

import "fmt"

func adder() func(int) int {
	sum := 0
	return func(v int) int {
		sum += v
		return sum
	}
}

/**
正统
*/
type iAdder func(int) (int, iAdder)

func adder2(base int) iAdder {
	return func(v int) (int, iAdder) {
		return base + v, adder2(base + v)
	}
}

func main() {
	a := adder2(0)
	for i := 0; i < 9; i++ {
		var s int
		s, a = a(i)
		fmt.Printf("0+1+...%d=%d\n", i, s)
	}
}

2.闭包的应用

  • 更为自然,不需要修饰如何访问自由变量
  • 没有lambda表达式,但是有匿名函数

扩展:

二叉树遍历(前序、中序、后序、层次遍历、深度优先、广度优先)

二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的。对于二叉树,有深度遍历和广度遍历,深度遍历有前序、中序以及后序三种遍历方法,广度遍历即我们平常所说的层次遍历。因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不仅容易理解而且代码很简洁,而对于广度遍历来说,需要其他数据结构的支撑,比如堆了。所以,对于一段代码来说,可读性有时候要比代码本身的效率要重要的多。

四种主要的遍历思想为:

前序遍历:根结点 —> 左子树 —> 右子树

中序遍历:左子树—> 根结点 —> 右子树

后序遍历:左子树 —> 右子树 —> 根结点

层次遍历:只需按层次遍历即可

例如,求下面二叉树的各种遍历

Google资深工程师深度讲解Go语言-函数式编程(六)

 

前序遍历:1  2  4  5  7  8  3  6 

中序遍历:4  2  7  5  8  1  3  6

后序遍历:4  7  8  5  2  6  3  1

层次遍历:1  2  3  4  5  6  7  8

 

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111711.html原文链接:https://javaforall.net

(0)
上一篇 2022年2月16日 下午7:00
下一篇 2022年2月16日 下午7:00


相关推荐

  • win10网络共享打印机设置

    win10网络共享打印机设置win10 系统设置网络打印机共享 局域网访问设置如下 注意 以下设置只针对 win10 专业版及以上版本才有用 因为家庭版的 win10 是没有 本地访问策略 设置的 1 win 键 R 打开 运行 输入 secpol msc 打开本地安全策略 2 打开 本地策略 gt 安全选项 gt 网络访问 本地账户的共享和安全模型 修改为 仅来宾 对本地用户 3 打开 本地策略 gt 安全选项 gt 账户 来宾账户状态 修改为 已启用 4 打开 本地策略 gt

    2026年3月19日
    2
  • hive表数据去重

    hive表数据去重

    2021年5月13日
    151
  • 【n8n教程】Sub-Workflow转换:让你的工作流更模块化、更高效

    【n8n教程】Sub-Workflow转换:让你的工作流更模块化、更高效

    2026年3月13日
    3
  • PyCharm 配置运行脚本

    PyCharm 配置运行脚本PyCharm 配置运行脚本的命令行参数 运行 编辑配置 Parameters PyCharm 配置运行脚本的运行环境 运行 编辑配置 Environment 运行环境包括环境变量 解释器 PyCharm 配置运行脚本前的启动工具 运行 编辑配置 启动前的任务 可以运行外部工具 其他配置 浏览器等

    2026年3月27日
    2
  • goland2021 激活(已测有效)

    goland2021 激活(已测有效),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月14日
    125
  • 跨平台应用开发进阶(十五) :uni-app 自定义 showToast并实现下载进度条

    跨平台应用开发进阶(十五) :uni-app 自定义 showToast并实现下载进度条大话设计模式(四)单例模式的优与劣前言首先来明确一个问题,那就是在某些情况下,有些对象,我们只需要一个就可以了,比如,一台计算机上可以连好几个打印机,但是这个计算机上的打印程序只能有一个,这里就可以通过单例模式来避免两个打印作业同时输出到打印机中,即在整个的打印过程中我只有一个打印程序的实例。简单说来,单例模式(也叫单件模式)的作用就是保证在整个应用程序的生命周期中,任何一个时刻,

    2022年6月20日
    260

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号