bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

小代碼二叉樹添加樹狀打印及倒立打印

  //bug    last line can not swap with n-1
//http://www.zhihu.com/question/22547591/
 #include<iostream>
 #include<queue>
#include <queue>  
#include <vector>  
#include <list>  
#include <math.h> 
#include <cstdio> 
using namespace std;
  int ii=0;
int Find( char x,int size,int zeroIndex)
{
    switch (x)
    {
    case 's': //上移 就是找到零下面的那個數(shù)字的位置 也就是序號增加一行 也就是+4
        {
        if ( zeroIndex<size - 4)
        {
            return zeroIndex + 4;
        }
        }
        break;
    case 'x': //下移
        {
//        if (zeroIndex<size-4 && zeroIndex>3)
        if (  zeroIndex>3)
        {
            return zeroIndex - 4;
        }
        }
        break;
    case 'c': 
        {
        if ( zeroIndex%4!=0 )
        {
            return zeroIndex - 1;
        }
        }
        break;
    case 'z':  //左移 主要是判斷空白是否在右邊緣
        {
        if (zeroIndex%4!=3)
        {
            return zeroIndex + 1;
        }
        }
        break;
    default:
        break;
    }   
    return -1;
}
 
 
//交換數(shù)組中zero和next的位置
void SwapIndex(int *ary,int zero, int next)
{
    if (-1 == next)
    {
        return ;
    }
    int t = ary[zero];
    ary[zero] = ary[next];
    ary[next] = t; 
}//DLR
 
void Update(int *ary, int size,char com)
{
    int zeroIndex = 0; //零的序號
    for (int i = 0.; i< size ; i++)
    {
        if (ary[i] == 0)
        {
            zeroIndex = i;
            break;
        }
    }
     
    int nextIndex = Find(com,size,zeroIndex); //獲取跟零相鄰(根據(jù)com不同 取上下左右)的那個數(shù)字的序號
    SwapIndex(ary,zeroIndex,nextIndex);
 
}
 
void Show(int *ary, int size)
{  ii++;
    for (int i  = 0 ; i <size; i++)
    {
        if(i % 4 == 0) //假設每行4個數(shù)字
        {
            cout<<endl<<endl;
        }
        if (ary[i]!=0)
        {
        cout<<"\t"<<ary[i];
        }
        else
        {
            cout<<"\t";
        }
    }
    //cout<<endl<<"請輸入方向(1234):";
   cout<<endl<<"  "<<ii<<endl<<"請輸入方向(sxzc):";
}
 
bool ProcessCommand(int *ary, int size,  char com)
{
   //    system("cls");
    Update(ary,size,com); //更新地圖
    Show(ary,size); //顯示新的地圖
    return true;
}
 
 
char GetCommand() //假設只返回4個值 代表四個方向
{
//int test = 1;
char  test='s';
cin>>test;//先測試一下
return test;
}
 
 
void Process(int *ary, int size)
{
   /// int com = 0;
   char  com='s';
    while(ProcessCommand(ary,size,com))
    {
         com = GetCommand();    
    }
 
}
 
 
int pintu()
{
    int ary[16]; //數(shù)字0 代表空白
    for (int i=0;i<16; i++)
    {
        ary[i] = i;
    }
    Process(ary,16);
    return 0;
}


















/////////////////////////////////////////////////////////////////////////


















template<class T>  
struct Binary_node  
{  
    T data;  
    Binary_node<T>* left;  
    Binary_node<T>* right;  
    Binary_node();  
    Binary_node(const T &x);  
};  
    
template<class T>  
class Binary_tree  
{  
public:  
    Binary_tree():root(NULL){}; 
    Binary_tree(const Binary_tree<T>&original);  
    Binary_tree & operator=(const Binary_tree<T>&original); 
    ~Binary_tree();   
    bool empty() const;  
    void preorder(void (*visit)(T &));  /*/ DLR   /*/ 
    void inorder(void  (*visit)(T &));  /*/ LDR  /*/
    void postorder(void (*visit)(T &)); /*/ LRD  /*/ 
    int size() const;                       /*/ Binary_tree大小/*/      
    int height() const;  
    void clear();  
    void insert(const T& x);  
    void reverse();                         /*/ 鏡像翻轉 /*/
    const Binary_node<T>* get_root() const; 
    void leaf()
   {
    Binary_node<T> *b;
   cout<<"leaf number:"<<_leaf(root)+1<<endl;
   cout<<"and the leaf element :"<<endl;
while(!q.empty())
{
    b=q.front(); cout<<b->data<<" "<<endl;q.pop();
 }  
   }
 void createlay()
   {
    Binary_node<T>*cur=root;
    Binary_node<T>*p=root;
     queue<Binary_node<T>* > q;  
     Binary_node<T> *b;
    int f=1,r=0;
    T c;
    cin>>c;
    root=new Binary_node<T>; q.push(root);  root->data=c;
   while(c!=-1)
    {
       if(r%2==0)
              {root->left=new Binary_node<T>;  q.push(root->left);}
       else
              {root->right=new Binary_node<T>;  q.push(root->right);}
       if(r%2==1)f++;if(f%2==0)root=q.front(); q.pop();
      r++;
    cin>>c;
    }
   }  
void fun(int n)
{ 
int m=pow(2,n)-1; queue<int> p;
int i,j,k=0;
  n=n+1;
 while(n--)
 { m=pow(2,k+1)-1;
   for(i=0;i<m;i++)
  {
    if(i%2==0) p.push(k); 
    else      {p.push(p.front());p.pop();}
   }
  k++;
 }
  //the end only add pow(2,n)-2 number ;
 Binary_node<T> *b ;
  _fun(root);
  q.push(root);
//while((!p.empty())&&(!q.empty()))
while((q.size()>1))
{  p.pop();
for(i=0;i<p.front();i++)cout<<"*"; p.pop();
   q.pop(); 
   b=q.front();cout<<b->data<<" "<<endl;
    q.pop();
} 
 
}
   void createBiTree()
   {
    //Binary_node<T>*b=root;
   _createBiTree(root);
   }  
 
    void lay(int n)                         /*/ 層次打印 /*/
   {  //assert(root)
      int k=1; int m=1;int i=0;
      Binary_node<T> *b=root;
      queue<Binary_node<T>* > q;  
          q.push(b);  
    while(!q.empty())
  {
     b=q.front();  if(b->left) q.push(b->left); if(b->right) q.push(b->right);
     m=pow(2,k-1); for(i=0;i<n/2;i++) cout<<" ";cout<<b->data; q.pop();
     while(--m)
       {
        for(i=0;i<2*(n/2)+1;i++) cout<<" "; if(!q.empty()){ b=q.front();  if(b->left) q.push(b->left); if(b->right) q.push(b->right);cout<<b->data; q.pop();}
else cout<<"#";
       }
      cout<<endl;
      n=n/2; 
      k++;
   }
 

}

    //一些遞歸輔助函數(shù)  
private:      
    int recursive_size(const Binary_node<T>*root) const;  
    int recursive_height(const Binary_node<T>*root) const;  
    void equal(Binary_node<T>*&sub_root,const Binary_node<T>*orig_node);  
    void recursive_reverse(Binary_node<T> * & sub_root);  
    void recursive_clear(Binary_node<T> * & sub_root);  
    void recursive_insert(Binary_node<T> * & sub_root, const T& x);  
    void recursive_inorder(Binary_node<T> * sub_root, void (*visit)(T &));  
    void recursive_preorder(Binary_node<T> * sub_root, void (*visit)(T &));  
    void recursive_postorder(Binary_node<T> * sub_root, void (*visit)(T &)); 
    void _fun(Binary_node<T> * sub_root)
{
if(sub_root==NULL){q.push(root);  return;}
_fun(sub_root->right);
if(sub_root!=NULL) {q.push(sub_root);}
  
_fun(sub_root->left);
}
    int _leaf(Binary_node<T> * sub_root)
{ 
    if(NULL == sub_root) return 0;  
    if(NULL == sub_root->left&& NULL == sub_root->right)  
       { return 1;  q.push(sub_root);}
    return _leaf(sub_root->left) + _leaf(sub_root->right); 
}
 void _createBiTree(Binary_node<T> *&sub_root)
 {
    T c;  
    cin >> c;  
     
/*************/
  if(-1== c)  sub_root = NULL;  
    else  
    {  
        sub_root = new Binary_node<T>; 
        sub_root->data = c;  
        _createBiTree(sub_root->left);  
        _createBiTree(sub_root->right);  
    }  
 
/*************/ 
} 
protected:  
    Binary_node<T>* root;  
    queue<Binary_node<T>* > q;
    
};
////////////////////////////////////////////  

#ifndef BINARY_TREE_CPP_X  
#define BINARY_TREE_CPP_X  
  
template<class T>  
Binary_node<T>::Binary_node()  
{  
    left = right = NULL;  
}  
template<class T>  
Binary_node<T>::Binary_node(const T &x)  
{  
    left = right = NULL;  
    data = x;  
}  
template<class T>  
Binary_tree<T>::Binary_tree(const Binary_tree<T>&original)  
{  
    root = original.get_root();  
}  
template<class T>  
void Binary_tree<T>::recursive_preorder(Binary_node<T>*sub_root, void (*visit)(T&))  
{//先序遍歷的遞歸函數(shù)  
    if (sub_root!=NULL)  
    {  
        (*visit)(sub_root->data);  
        recursive_preorder(sub_root->left, visit);  
        recursive_preorder(sub_root->right, visit);  
    }  
}  
template<class T>  
void Binary_tree<T>::preorder(void (*visit)(T&))  
{//先序遍歷  
    recursive_preorder(root, visit);  
}
template<class T>  
void Binary_tree<T>::recursive_inorder(Binary_node<T>*sub_root, void(*visit)(T&))  
{//中序遍歷的遞歸函數(shù)  
    if(sub_root!=NULL)  
    {  
        recursive_inorder(sub_root->left, visit);  
        (*visit)(sub_root->data);  
        recursive_inorder(sub_root->right, visit);  
    }  
}  
template<class T>  
void Binary_tree<T>::inorder(void (*visit)(T&))  
{//中序遍歷  
    recursive_inorder(root, visit);  
}  
 
template<class T>  
void Binary_tree<T>::recursive_postorder(Binary_node<T>*sub_root, void (*visit)(T&))  
{//后序遍歷的遞歸函數(shù)  
    if (sub_root!=NULL)  
    {  
        recursive_postorder(sub_root->left, visit);  
        recursive_postorder(sub_root->right, visit);  
        (*visit)(sub_root->data);  
    }  
}  
template<class T>  
void Binary_tree<T>::postorder(void (*visit)(T&))  
{//后序遍歷  
    recursive_postorder(root, visit);  
}  
 
  
 
//return tree height, if only one node then return 1  
template<class T>  
int Binary_tree<T>::height() const  
{  
    return recursive_height(root);  
}  
#endif
#define max MAX  
template<class Comparable>  
Comparable MAX(const Comparable& a, const Comparable& b)  
{  
    return a > b ? a : b;  
}  
template<class T>  
int Binary_tree<T>::recursive_height(const Binary_node<T>*root) const  
{  
    if(root == NULL)  
        return 0;  
    else  
        return 1 + max(recursive_height(root->left) , recursive_height(root->right)) ;  
}  
#undef max  
 
//return the size of tree  
template<class T>  
int Binary_tree<T>::size() const  
{  
    return recursive_size(root);  
}  
template<class T>  
int Binary_tree<T>::recursive_size(const Binary_node<T>*root) const  
{  
    if(root == NULL)  
        return 0;   
    else  
        return 1 + recursive_size(root->left) + recursive_size(root->right) ;  
}  
//the tree is empty ?  
template<class T>  
bool Binary_tree<T>::empty() const  
{  
    return root == NULL;  
}  
//insert x to the tree  
template<class T>  
void Binary_tree<T>::insert(const T& x)  
{  
    recursive_insert(root, x);  
}  
//the recursive function of insert,  
//insert x in the less height side,  
//if both sides are same height then insert to the left  
//第一個參數(shù)必須使用引用否則插入失敗,而其他不涉及數(shù)據(jù)改動的函數(shù)則不需要  
//引用傳參時不會發(fā)生值拷貝,如果不加引用,會先在函數(shù)的棧空間拷貝一個root,但當函數(shù)  
//結束時這個拷貝就會被銷毀,所以會導致插入失敗  
template<class T>  
void Binary_tree<T>::recursive_insert(Binary_node<T>*&sub_root, const T& x)  
{  
    if(sub_root == NULL)  
    {  
        Binary_node<T>* ins_data = new Binary_node<T>(x);  
        sub_root = ins_data;  
        return;  
    }  
    else  
    {  
        if(recursive_height(sub_root->left) > recursive_height(sub_root->right))  
            recursive_insert(sub_root->right, x);  
        else  
            recursive_insert(sub_root->left, x);  
    }  
}  
 


template<class T>  
Binary_tree<T>::~Binary_tree()  
{  
    clear();  
}  
template<class T>  
void Binary_tree<T>::clear()  
{  
    recursive_clear(root);  
}  
/*/ recursive function for destroy tree /*/ 
template<class T>  
void Binary_tree<T>::recursive_clear(Binary_node<T>*&sub_root)  
{/*/兩個版本都OK /*/ 
#if 0  
    if(sub_root != NULL)  
    {  
        recursive_clear(sub_root->left);  
        recursive_clear(sub_root->right);  
        delete sub_root;  
        sub_root = NULL;  
    }  
#else  
    if(sub_root->left!=NULL)  
        recursive_clear(sub_root->left);  
    if(sub_root->right!=NULL)  
        recursive_clear(sub_root->right);  
    delete sub_root;  
    sub_root = NULL;  
#endif  
}  
/*/  get the root /*/ 
template<class T>  
const Binary_node<T>* Binary_tree<T>::get_root() const  
{  
    return root;  
}  
/*/ deep copy /*/ 
template<class T>  
Binary_tree<T>& Binary_tree<T>::operator =(const Binary_tree<T>&original)  
{  
    equal(root, original.get_root());  
    return *this;  
}  
template<class T>  
void Binary_tree<T>::equal(Binary_node<T>*&sub_root,const Binary_node<T>*orig_node)  
{  
    if(empty())  
        sub_root = new Binary_node<T>(orig_node->data);  
    if(orig_node->left!=NULL)  
    {  
        sub_root->left = new Binary_node<T>(orig_node->left->data);  
        equal(root->left, orig_node->left);  
    }  
    if(orig_node->right!=NULL)  
    {  
        sub_root->right = new Binary_node<T>(orig_node->right->data);  
        equal(root->right, orig_node->right);  
    }  
}  
 
template<class T>  
void Binary_tree<T>::reverse()  
{  
    recursive_reverse(root);  
}  
template<class T>  
void Binary_tree<T>::recursive_reverse(Binary_node<T> * & sub_root)  
{  
    if(sub_root!=NULL)  
    {  
        Binary_node<T>* temp = NULL;  
        temp = sub_root->left;  
        sub_root->left = sub_root->right;  
        sub_root->right = temp;  
        recursive_reverse(sub_root->left);  
        recursive_reverse(sub_root->right);  
    }  
}  
 
 
  void test10()
{
Binary_tree<int> dd;  
//dd.createBiTree(); 
dd.createlay();
dd.lay(9); 
}
void print( int& x);  
void test11()  
{  
    Binary_tree<int> dd;  
    dd.insert(1);  
    dd.insert(2);  
    dd.insert(3);  
   
 dd.insert(4);  
    dd.insert(5);  
    dd.insert(6);  
    dd.insert(7);
   /***************  
Binary_tree<int> ww;  
    ww = dd;  
    ww.insert(10);  
     ww.insert(7);  
     cout<<"preorder:";  
    dd.preorder(print);  
     cout<<endl;  
    cout<<"preorder:";  
    ww.preorder(print);  
     cout<<endl; 
     dd.lay(9);  
    cout<<endl; 
    dd.reverse();  
    cout<<"preorder:";  
    ***************/
     dd.preorder(print);  cout<<endl; 
     dd.lay(9);  
    //dd.leaf();
dd.fun(4);
    cout<<endl;    
}  
void print( int& x)  
{  
    cout<<x<<" ";  
} 
 
 
int main()
{
//pintu();
test11();
    return 0;  
}  

/////////// /****************
   
//cout<<b->left->data<<"left"<<endl;
//if(b->left==NULL&&b->right==NULL){cout<<"#"<<endl;q.pop();}
             //  else {cout<<b->data<<" "<<endl;q.pop();}
 //if(b->left->data!=2&&b->left->data!=3){cout<<"#"<<endl;q.pop();}
     //           else {cout<<b->data<<" "<<endl;q.pop();}

小代碼  二叉樹 添加樹狀打印及倒立打印

創(chuàng)新互聯(lián)公司一直通過網(wǎng)站建設和網(wǎng)站營銷幫助企業(yè)獲得更多客戶資源。 以"深度挖掘,量身打造,注重實效"的一站式服務,以網(wǎng)站設計、做網(wǎng)站、移動互聯(lián)產品、成都營銷網(wǎng)站建設服務為核心業(yè)務。十載網(wǎng)站制作的經驗,使用新網(wǎng)站建設技術,全新開發(fā)出的標準網(wǎng)站,不但價格便宜而且實用、靈活,特別適合中小公司網(wǎng)站制作。網(wǎng)站管理系統(tǒng)簡單易用,維護方便,您可以完全操作網(wǎng)站資料,是中小公司快速網(wǎng)站建設的選擇。

網(wǎng)站名稱:小代碼二叉樹添加樹狀打印及倒立打印
轉載來于:http://vcdvsql.cn/article44/pegiee.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作微信小程序靜態(tài)網(wǎng)站微信公眾號小程序開發(fā)外貿建站

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設