运用二叉排序树进行排序

AlespRless · · 638 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

```go 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) } //appendValues将元素按顺序追加到values里面,然后返回结果slice 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 { //等价于返回&tree{value: value} 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 slice []int for i:= 0;i < 10000;i++ { slice = append(slice,rand.Intn(100)) } fmt.Println(time.Now()) Sort(slice) fmt.Println(time.Now()) } ```

有疑问加站长微信联系(非本文作者))

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

638 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传