亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

LintCode-排序列表轉換為二分查找樹分析及實例

 更新時間:2017年04月25日 10:34:10   投稿:lqh  
這篇文章主要介紹了LintCode-排序列表轉換為二分查找樹分析及實例的相關資料,需要的朋友可以參考下

給出一個所有元素以升序排序的單鏈表,將它轉換成一棵高度平衡的二分查找樹

您在真實的面試中是否遇到過這個題? 

分析:就是一個簡單的遞歸,只是需要有些鏈表的操作而已

代碼:

/** 
 * Definition of ListNode 
 * class ListNode { 
 * public: 
 *  int val; 
 *  ListNode *next; 
 *  ListNode(int val) { 
 *   this->val = val; 
 *   this->next = NULL; 
 *  } 
 * } 
 * Definition of TreeNode: 
 * class TreeNode { 
 * public: 
 *  int val; 
 *  TreeNode *left, *right; 
 *  TreeNode(int val) { 
 *   this->val = val; 
 *   this->left = this->right = NULL; 
 *  } 
 * } 
 */ 
class Solution { 
public: 
 /** 
  * @param head: The first node of linked list. 
  * @return: a tree node 
  */ 
 TreeNode *sortedListToBST(ListNode *head) { 
  // write your code here 
  if(head==nullptr) 
   return nullptr; 
  int len = 0; 
  ListNode*temp = head; 
  while(temp){len++;temp = temp->next;}; 
  if(len==1) 
  { 
   return new TreeNode(head->val); 
  } 
  else if(len==2) 
  { 
   TreeNode*root = new TreeNode(head->val); 
   root->right = new TreeNode(head->next->val); 
   return root; 
  } 
  else 
  { 
   len/=2; 
   temp = head; 
   int cnt = 0; 
   while(cnt<len) 
   { 
    temp = temp->next; 
    cnt++; 
   } 
   ListNode*pre = head; 
   while(pre->next!=temp) 
    pre = pre->next; 
   pre->next = nullptr; 
   TreeNode*root = new TreeNode(temp->val); 
   root->left = sortedListToBST(head); 
   root->right = sortedListToBST(temp->next); 
   return root; 
    
  } 
 } 
}; 

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

您可能感興趣的文章:

相關文章

  • C++ const限定符以及頂層const和底層const的案例詳解

    C++ const限定符以及頂層const和底層const的案例詳解

    這篇文章主要介紹了C++ const限定符以及頂層const和底層const的案例詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-09-09
  • 深入解析int(*p)[]和int(**p)[]

    深入解析int(*p)[]和int(**p)[]

    以下是對int(*p)[]和int(**p)[]的使用進行了詳細的分析介紹,需要的朋友可以參考下
    2013-07-07
  • C++編程中使用設計模式中的policy策略模式的實例講解

    C++編程中使用設計模式中的policy策略模式的實例講解

    這篇文章主要介紹了C++編程中使用設計模式中的policy策略模式的實例講解,文章最后對策略模式的優(yōu)缺點有一個簡單的總結,需要的朋友可以參考下
    2016-03-03
  • C語言中輸入輸出流與緩沖區(qū)的深入講解

    C語言中輸入輸出流與緩沖區(qū)的深入講解

    一般情況下,由鍵盤輸入的字符并沒有直接送入程序,而是被存儲在一個緩沖區(qū)當中。下面這篇文章主要給大家介紹了關于C語言中輸入輸出流與緩沖區(qū)的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2018-09-09
  • C語言實現(xiàn)通用數據結構之通用集合(HashSet)

    C語言實現(xiàn)通用數據結構之通用集合(HashSet)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)通用數據結構之通用集合,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • c語言如何實現(xiàn)DES加密解密

    c語言如何實現(xiàn)DES加密解密

    這篇文章主要介紹了c語言如何實現(xiàn)DES加密解密問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 好用的C++ string Format“函數”介紹

    好用的C++ string Format“函數”介紹

    大家好,本篇文章主要講的是好用的C++ string Format“函數”介紹,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • C++類中const修飾的成員函數及日期類小練習

    C++類中const修飾的成員函數及日期類小練習

    將const修飾的“成員函數”稱之為const成員函數,const修飾類成員函數,表明在該成員函數中不能對類的任何成員進行修改,下面這篇文章主要給大家介紹了關于C++類中const修飾的成員函數及日期類小練習?的相關資料,需要的朋友可以參考下
    2023-01-01
  • C語言中讀寫交替時出現(xiàn)的問題分析

    C語言中讀寫交替時出現(xiàn)的問題分析

    讀寫命令交替,一定要使用fseek重新定位,否則出現(xiàn)輸入顯示混亂,這篇文章主要介紹了C語言中讀寫交替時出現(xiàn)的問題分析,需要的朋友可以參考下
    2022-12-12
  • 深入分析C語言中結構體指針的定義與引用詳解

    深入分析C語言中結構體指針的定義與引用詳解

    本篇文章是對C語言中結構體指針的定義與引用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05

最新評論