#13894: 解題報告


lltzpp (lltzpp)

學校 : 國立成功大學
編號 : 47754
來源 : [112.78.95.38]
最後登入時間 :
2024-10-19 10:23:34
d526. Binary Search Tree (BST) | From: [175.181.209.176] | 發表日期 : 2018-05-12 21:09

// by. MiohitoKiri5474
#include<bits/stdc++.h>

// 加速用,編譯器優化
#pragma GCC optimize ( "O3" )
#pragma loop_opt ( on )

struct node{
    node *leftSon, *rightSon;
    int val;

    // 建構子
    node ( int _val ): val ( _val ), leftSon ( nullptr ), rightSon ( nullptr ) {}
} *root;

inline void insert ( int n, node *&o ){ // 用*&直接對指標做修改,不用回傳
    if ( !o ) // 如果是空的樹,建構一顆新的
        o = new node ( n );
    else{
        if ( n > o -> val ) // 較大,往右遞迴
            insert ( n, o -> rightSon );
        else // 較小,往左遞迴
            insert ( n, o -> leftSon );
    }
}

inline void print ( node *o ){
    if ( !o ) // 如果是空的樹,結束不繼續遞迴
        return;
    cout << o -> val << ' ';
    // 先往左,再往右
    print ( o -> leftSon );
    print ( o -> rightSon );
}

int main(){
    // 輸入優化
    ios::sync_with_stdio ( false );
    cin.tie ( 0 );
    cout.tie ( 0 );

    int n, in;
    while ( cin >> n >> in ){
        n--;
        root = new node ( in ); // 建構一顆全新的樹
        while ( n-- ){
            cin >> in;
            insert ( in, root );
        }

        print ( root );
        cout << '\n';
    }
}

 
ZeroJudge Forum