golang使用一个二叉树来实现一个插入排序
思路不太好理解,请用断点
package main
import "fmt"
type tree struct {
    value       int
    left, right *tree
}
func Sort(values []int) {
    var root *tree
    for _, v := range values {
        root = add(root, v)
    }
    appendValues(values[:0], root)
}
func appendValues(values []int, t *tree) []int {
    if t != nil {
        values = appendValues(values, t.left)
        values = append(values, t.value)
        values = appendValues(values, t.right)
    }
    return values
}
func add(t *tree, value int) *tree {
    if t == nil {
        t = new(tree)
        t.value = value
        return t
    }
    if value < t.value {
        t.left = add(t.left, value)
    } else {
        t.right = add(t.right, value)
    }
    return t
}
func main() {
    var list = []int{5, 1, 8, 3, 6}
    fmt.Println(list)
    Sort(list)
    fmt.Println(list)
}
golang使用一个二叉树来实现一个插入排序的更多相关文章
- 二叉树的下一个结点(剑指offer_8)
		
题目描述 给定一个二叉树和其中一个结点,请找出中序遍历顺序的下一个结点并返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针. public class TreeLinkNode { i ...
 - 剑指offer:JZ8 二叉树的下一个结点
		
JZ8 二叉树的下一个结点 描述 给定一个二叉树其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的next指针.下图为一棵有9个节点的二叉 ...
 - LeetCode 606. Construct String from Binary Tree (建立一个二叉树的string)
		
You need to construct a string consists of parenthesis and integers from a binary tree with the preo ...
 - 剑指offer(57)二叉树的下一个节点
		
题目描述 给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针. 题目分析 这题一定要画图,因为只有画图我们才能分清楚下 ...
 - 剑指Offer 57. 二叉树的下一个结点 (二叉树)
		
题目描述 给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针. 题目地址 https://www.nowcoder.c ...
 - 【Java】 剑指offer(7) 二叉树的下一个结点
		
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 给定一棵二叉树和其中的一个结点,如何找出中序遍历顺序的下一个结点? ...
 - 【IT笔试面试题整理】判断一个二叉树是否是平衡的?
		
[试题描述]定义一个函数,输入一个链表,判断链表是否存在环路 平衡二叉树,又称AVL树.它或者是一棵空树,或者是具有下列性质的二叉树:它的左子树和右子树都是平衡二叉树,且左子树和右子树的高度之差之差的 ...
 - 剑指offer五十七之二叉树的下一个结点
		
一.题目 给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针. 二.思路 结合图,我们可发现分成两大类: 1.有右子树 ...
 - (剑指Offer)面试题58:二叉树的下一个结点
		
题目: 给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针. 思路: 考虑中序遍历的过程, 如果当前结点存在右子节点, ...
 
随机推荐
- 2018-2019-2 《网络对抗技术》Exp7 网络欺诈防范 20165326
			
网络欺诈防范 实践内容 本实践的目标理解常用网络欺诈背后的原理,以提高防范意识,并提出具体防范方法.具体实践有 简单应用SET工具建立冒名网站 ettercap DNS spoof 结合应用两种技术, ...
 - Simplifying Failures
			
# # Finish the delta debug function ddmin # import re def test(s): print s, len(s),repr(s) if re.sea ...
 - python棱形继承(钻石继承)
			
class A(object): def func(self): print('A') class B(A): def func(self): super().func() print('B') cl ...
 - Python中单引号和双引号的作用
			
一.单引号和双引号 在Python中我们都知道单引号和双引号都可以用来表示一个字符串,比如 str1 = 'python' str2 = "python" str1和str2是没有 ...
 - js的prototype理解
			
转载:https://www.cnblogs.com/douyage/p/8630529.html 在典型的面向对象的语言中,如java,都存在类(class)的概念,类就是对象的模板,对象就是类的实 ...
 - ajax上传图片报错TypeError: 'append' called on an object that does not implement interface Fo
			
使用FormData时报错:TypeError: 'append' called on an object that does not implement interface FormData 解决办 ...
 - GIS地理工具案例教程——批量合并影像
			
GIS地理工具案例教程——批量合并影像 商务合作,科技咨询,版权转让:向日葵,135—4855__4328,xiexiaokui#qq.com 描述:合并目录下的所有影像 功能:对指定工作空间下的栅格 ...
 - python try except 出现异常时,except 中如何返回异常的信息字符串
			
https://docs.python.org/3/tutorial/errors.html#handling-exceptions https://docs.python.org/3/library ...
 - AndoridSQLite数据库开发基础教程(7)
			
AndoridSQLite数据库开发基础教程(7) 为空表添加数据 开发者可以单击Data按钮,看到Students表中是没有数据的,创建好的Students表是一个空表.如图1.15所示.如果开发者 ...
 - 005-guava 集合-集合工具类-java.util.Collections中未包含的集合工具[Maps,Lists,Sets],Iterables、Multisets、Multimaps、Tables
			
一.概述 工具类与特定集合接口的对应关系归纳如下: 集合接口 属于JDK还是Guava 对应的Guava工具类 Collection JDK Collections2:不要和java.util.Col ...