一維數組存儲線段樹要開多大的數組?

 Java代碼 複製代碼 收藏代碼java

  1. import java.util.Scanner;
  2. /*線段樹空間計算程序 Power By:Comzyh*/
  3.  
  4. class segment {//線段樹節點
  5. int b,e;
  6. }
  7.  
  8. public class SegmentTree{//線段樹,用數組實現
  9. static int M=5000000;
  10. segment seg[];
  11.  
  12. int Nnode;//節點數
  13. int LastNode;//最後一個節點
  14.  
  15. public SegmentTree(){
  16. seg=new segment[M];
  17. for(int i=0;i<M;i++)
  18. seg[i]=new segment();
  19. }
  20.  
  21.  
  22. void build(int b, int e, int root){//構造線段樹
  23. Nnode++;
  24. if (root>LastNode)
  25. LastNode=root;
  26. seg[root].b=b;
  27. seg[root].e=e;
  28. if (b==e)
  29. return;
  30. int mid =(b+e)>>1;
  31. build(b,mid,root<<1);
  32. build(mid+1,e,(root<<1)+1);
  33. }
  34.  
  35. public int getNnode(){
  36. return Nnode;
  37. }
  38.  
  39. public int getLastNode(){
  40. return LastNode;
  41. }
  42.  
  43. public static void main(String args[]){
  44. Scanner in=new Scanner(System.in);
  45. int N;
  46. while (true){
  47. System.out.printf("請輸入區間長度:\n");
  48. N=in.nextInt();
  49. if (N==0) break;
  50. SegmentTree st=new SegmentTree();
  51. st.build(1,N,1);
  52. System.out.printf("線段樹構造完成, 共有%d 節點,最後一個節點是: %d\n",st.getNnode(),st.getLastNode());
  53. //注意:節點個數老是2N-1
  54. }
  55. }
  56. }



運行:
C:\ex>java SegmentTree
請輸入區間長度:
5
線段樹構造完成, 共有9 節點,最後一個節點是: 9
請輸入區間長度:
10
線段樹構造完成, 共有19 節點,最後一個節點是: 25
請輸入區間長度:
100000
線段樹構造完成, 共有199999 節點,最後一個節點是: 262141 node

相關文章
相關標籤/搜索