• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            聚星亭

            吾笨笨且懶散兮 急須改之而奮進
            posts - 74, comments - 166, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
            最近把我知道的大牛的博客都拜讀了一下,看到這個,感覺能用到,就轉(zhuǎn)過來了,省的以后自己寫,偷個懶,
            嘿嘿`~

            #include <stdio.h>
            #include 
            <windows.h>

            #define STACK_STRUCT_SIZE 1048576

            typedef 
            struct _BST_NODE {
                PVOID data;
                
            struct _BSTNODE *left, *right;
            } BST_NODE, 
            *PBST_NODE;

            typedef 
            struct _STACK_STRUCT {
                ULONG ptr;
                PVOID data[STACK_STRUCT_SIZE];
            } STACK_STRUCT, 
            *PSTACK_STRUCT;

            VOID IcyAllocateStack(OUT PSTACK_STRUCT 
            *Stack)
            {
                PSTACK_STRUCT stack;
                stack 
            = malloc(sizeof(STACK_STRUCT));
                stack
            ->ptr = 0;
                
            *Stack = stack;
            }

            VOID IcyFreeStack(IN PSTACK_STRUCT Stack)
            {
                free(Stack);
            }

            BOOLEAN IcyPushStack(IN OUT PSTACK_STRUCT Stack, IN PVOID Data)
            {
                
            int ptr = Stack->ptr;
                
            if (ptr == STACK_STRUCT_SIZE - 1) {
                    
            return FALSE;
                } 
            else {
                    Stack
            ->data[ptr] = Data;
                    Stack
            ->ptr = ptr + 1;
                    
            return TRUE;
                }
            }

            BOOLEAN IcyPopStack(IN OUT PSTACK_STRUCT Stack, OUT PVOID 
            *Data)
            {
                
            int ptr = Stack->ptr;

                
            if (ptr) {
                    ptr
            --;
                    
            *Data = Stack->data[ptr];
                    Stack
            ->ptr = ptr;
                    
            return TRUE;
                } 
            else {
                    
            return FALSE;
                }
            }

            VOID IcyAllocateBSTNode(OUT PBST_NODE 
            *Node, IN PVOID Data)
            {
                PBST_NODE node;
                node 
            = malloc(sizeof(BST_NODE));
                node
            ->data = Data;
                node
            ->left = 0;
                node
            ->right = 0;
                
            *Node = node;
            }

            VOID IcyBSTInsertData(IN OUT PBST_NODE 
            *Node, IN PVOID Data)
            {
                
            while (1) {
                    
            if (*Node) {
                        
            if (Data < (*Node)->data) {
                            Node 
            = (PBST_NODE *)&((*Node)->left);
                        } 
            else {
                            Node 
            = (PBST_NODE *)&((*Node)->right);
                        }
                    } 
            else {
                        IcyAllocateBSTNode(Node, Data);
                        
            break;
                    }
                }
            }

            VOID IcyBSTMidOrder(IN PBST_NODE Node, VOID (
            *IN CALLBACK CallbackFunction) (PBST_NODE))
            {
                PSTACK_STRUCT stack;
                
            if (Node) {
                    IcyAllocateStack(
            &stack);
                    
            while (1) {
                        
            if (Node->left) {
                            
            if (!IcyPushStack(stack, Node)) break;
                            Node 
            = (PBST_NODE)Node->left;
                        } 
            else {
            loop:
                            CallbackFunction(Node);
                            
            if (Node->right) {
                                Node 
            = (PBST_NODE)Node->right;
                            } 
            else if (IcyPopStack(stack, (PVOID *)&Node)) {
                                
            goto loop;
                            } 
            else {
                                
            break;
                            }
                        }
                    }
                    IcyFreeStack(stack);
                }
            }

            VOID MidOrderCallback(PBST_NODE Node)
            {
                printf(
            "%d\n", Node->data);
            }

            int main()
            {
                BST_NODE 
            *tree = 0;
                
            int x;
                
            do {
                    scanf(
            "%d"&x);
                    IcyBSTInsertData(
            &tree, (PVOID)x);
                } 
            while (x);
                IcyBSTMidOrder(tree, MidOrderCallback);
                
            return 0;
            }

            (聲明:以上代碼轉(zhuǎn)載于 :iceboy @ baidu.hi

            Feedback

            # re: [轉(zhuǎn)載] 中序遍歷二叉樹, 非遞歸  回復(fù)  更多評論   

            2010-08-05 00:41 by 小天狼星
            這些基礎(chǔ)在許多公司的面試題中常見。估計你能考90分了。

            # re: [轉(zhuǎn)載] 中序遍歷二叉樹, 非遞歸[未登錄]  回復(fù)  更多評論   

            2010-08-08 22:26 by besterChen
            @小天狼星
            可惜,轉(zhuǎn)載的……

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            人人狠狠综合久久亚洲婷婷| 国内精品久久久久国产盗摄| 久久久无码精品午夜| 精品国产青草久久久久福利| 蜜臀久久99精品久久久久久| 久久综合伊人77777麻豆| 一本久久a久久精品亚洲| 日本精品久久久久中文字幕| 久久精品无码一区二区app| 久久精品国产亚洲AV无码娇色| 亚洲国产成人久久综合碰碰动漫3d| 狠狠色婷婷久久综合频道日韩| 久久久噜噜噜久久熟女AA片| 久久伊人五月天论坛| 精品久久久久久久久午夜福利| 久久无码AV中文出轨人妻| 国产激情久久久久影院小草| 国内精品久久久久久99蜜桃| 久久男人AV资源网站| 潮喷大喷水系列无码久久精品| 欧美大战日韩91综合一区婷婷久久青草 | 久久精品国产一区二区三区| 亚洲综合精品香蕉久久网| 国产高清美女一级a毛片久久w| 日韩乱码人妻无码中文字幕久久 | 久久夜色精品国产噜噜麻豆| 精品久久久无码中文字幕| 久久99精品国产99久久6男男| 久久精品国产亚洲av水果派| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 精品午夜久久福利大片| 亚洲欧洲日产国码无码久久99| 亚洲AV无码一区东京热久久| 午夜精品久久久久9999高清| 亚洲精品国产第一综合99久久| 久久综合伊人77777| 精品99久久aaa一级毛片| 久久久久久综合一区中文字幕 | 久久久久久国产精品美女| 国产精品伊人久久伊人电影| 草草久久久无码国产专区|