Posted on 2009-07-09 16:20 
Hero 阅读(318) 
评论(0)  编辑 收藏 引用  所属分类: 
代码如诗--ACM 
			 
			
		 
		 1 //HLOJ 1042  Accepted  15 276 1180 C++ 
 2 
 3 //二叉树的中序遍历
 4 //没有考虑到虚节点
 5 
 6 #include <iostream>
 7 using namespace std ;
 8 
 9 const int size = 20000 ;
10 int data[size] ;
11 
12 int tnum ;
13 int inn ;
14 char *blank = "" ;
15 bool istree = false ;
16 
17 int deep ;
18 
19 void DFS( int root )
20 {
21     if( root > inn ) return ;
22 
23     if( data[root] != 0 ) DFS( root * 2 ) ;
24 
25     if( data[root] != 0 )
26     {
27         printf( "%s%d", blank, data[root] ) ;
28         blank = " " ;
29         istree = true ;
30         deep = deep > root ? deep : root ;
31     }
32 
33     if( data[root] != 0 ) DFS( root * 2 + 1 ) ;
34 }
35 
36 int fpow( int a, int b )
37 {
38     int reval = 1 ;
39 
40     for( int i=1; i<=b; i++ )
41     {
42         reval = reval * a ;
43     }
44 
45     return reval ;
46 }
47 
48 int main()
49 {
50     while( cin >> tnum )
51     {
52         while( tnum -- )
53         {        
54             cin >> inn ;
55 
56             memset( data, 0, sizeof(data) ) ;
57             blank = "" ;
58             istree = false ;
59             deep = 0 ;
60 
61             for( int i=1; i<=inn; i++ )
62             {
63                 cin >> data[i] ;
64             }
65 
66             DFS( 1 ) ; cout << endl ;
67 
68             int cnt = 0 ; int num = 0 ;
69             while( num < deep && istree )
70             {
71                 num = num + fpow( 2, cnt ) ;                            
72                 cnt = cnt + 1 ;
73             }
74             
75             cout <<  cnt << endl ;
76         }
77     }
78 
79     return 0 ;
80 }