• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >数据结构 > 有序链表转换二叉搜索树

有序链表转换二叉搜索树

作者: 字体:[增加 减小] 来源:互联网 时间:2018-08-06

通过本文主要向大家介绍了Tree等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

给定一个单链表,其中的元素按升序排序,将其转换为高度平衡的二叉搜索树。

本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1。

示例:

给定的有序链表: [-10, -3, 0, 5, 9],

一个可能的答案是:[0, -3, 9, -10, null, 5], 它可以表示下面这个高度平衡二叉搜索树:

      0
     / \
   -3   9
   /   /
 -10  5
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public TreeNode sortedListToBST(ListNode head) {
        if(head==null)
            return null;
        if(head.next==null)
            return new TreeNode(head.val);
        ListNode fast=head;
        ListNode slow=head;
        ListNode preslow=slow;
        while(fast.next!=null && fast.next.next!=null)
        {
            preslow=slow;
            fast=fast.next.next;
            slow=slow.next;
        }
        fast=slow.next;
        TreeNode root=new TreeNode(slow.val);
        preslow.next=null;
        if (head!=slow)
            root.left=sortedListToBST(head);
        root.right=sortedListToBST(fast);
        return root;
    }
}

 

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2017-06-28数据结构C语言实现之二叉树
  • 2017-06-28数据结构教程 第十七课 实验三:栈的表示与实现及栈的应用
  • 2017-06-28java中实现希尔排序算法
  • 2017-06-28数据结构教程 第三十九课 索引文件
  • 2017-08-17面向对象编程(OOP)理解
  • 2017-06-28数据结构教程 第十五课 串的表示和实现
  • 2017-06-28oracle用存储过程加密一段字符串(3des算法)
  • 2017-08-17确定n微秒时高能质点和低能质点的数目
  • 2017-06-28数据结构教程 第十课 栈的表示与实现
  • 2017-06-28A*寻路初探

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 计算字符串的相似度
    • 链表的建立、插入和删除
    • 算法学习之旅,初级篇(30)-–删除链表内节点
    • 数据结构教程 第三十八课 文件概念、顺序文件
    • C#算法设计与分析-寻找素数
    • 数据结构教程 第十七课 实验三:栈的表示与实现及栈的应用
    • 数据结构教程 第十二课 实验二 循环链表实验
    • 面向对象编程(OOP)理解
    • 数据结构教程 第二十六课 图的定义与术语
    • 数据结构教程 第九课 循环链表与双向链表

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有