Binary Search with the find() Method
二分查找(java code)
 1 public int find(long searchkey)
public int find(long searchkey)
2 {
{
3 int lowerBound=0;
    int lowerBound=0;
4 int upperBound=nelems-1;
    int upperBound=nelems-1;
5 int curIn;
    int curIn;
6 while(true)
    while(true)
7 {
    {
8 curIn=(lowerBound+upperBound)/2;
        curIn=(lowerBound+upperBound)/2;
9 if(a[curIn]==searchKey)
        if(a[curIn]==searchKey)
10 return curIn;
            return curIn;
11 else if(lowerBound>upperBound)
        else if(lowerBound>upperBound)
12 return nElems;
            return nElems;
13 else
        else
14 {
        {
15 if(a[curIn]<searchKey]
            if(a[curIn]<searchKey]
16 lowerBound=curIn+1;
                lowerBound=curIn+1;
17 else
            else
18 upperbound=curIn-1;
            upperbound=curIn-1;
19 }
        }
20 }
    }
21 }
}
 public int find(long searchkey)
public int find(long searchkey)2
 {
{3
 int lowerBound=0;
    int lowerBound=0;4
 int upperBound=nelems-1;
    int upperBound=nelems-1;5
 int curIn;
    int curIn;6
 while(true)
    while(true)7
 {
    {8
 curIn=(lowerBound+upperBound)/2;
        curIn=(lowerBound+upperBound)/2;9
 if(a[curIn]==searchKey)
        if(a[curIn]==searchKey)10
 return curIn;
            return curIn;11
 else if(lowerBound>upperBound)
        else if(lowerBound>upperBound)12
 return nElems;
            return nElems;13
 else
        else14
 {
        {15
 if(a[curIn]<searchKey]
            if(a[curIn]<searchKey]16
 lowerBound=curIn+1;
                lowerBound=curIn+1;17
 else
            else18
 upperbound=curIn-1;
            upperbound=curIn-1;19
 }
        }20
 }
    }21
 }
}The OrdArray Class (排序数组 java code)
 1 class OrdArray
class OrdArray
2 {
{
3 private long[] a;
    private long[] a;
4 private  int nElems;
    private  int nElems;
5 
    
6 public OrdArray(int max)
    public OrdArray(int max)
7 {
    {
8 a=new long[max];
        a=new long[max];
9 nElems=0;
        nElems=0;
10 }
    }
11 
    
12 public int Size()
    public int Size()
13 {
    {
14 return nElems;
        return nElems;
15 }
    }
16 
    
17 public int find(long searchKey)
    public int find(long searchKey)
18 {
    {
19 int LowerBound=0;
        int LowerBound=0;
20 int UpperBound=nElems-1;
        int UpperBound=nElems-1;
21 int curIn;
        int curIn;
22 
        
23 while(true)
        while(true)
24 {
        {
25 curIn=(LowerBound+UpperBound)/2;
            curIn=(LowerBound+UpperBound)/2;
26 
            
27 if(a[curIn]==searchKey)
            if(a[curIn]==searchKey)
28 
                
29 return curIn;
             return curIn;
30 else if(LowerBound>UpperBound)
            else if(LowerBound>UpperBound)
31 
                
32 return  nElems;
            return  nElems;
33 
            
34 else
            else
35 {
            {
36 if(a[curIn]<searchKey)
                if(a[curIn]<searchKey)
37 {
                {
38 LowerBound=curIn+1;
                    LowerBound=curIn+1;
39 }
                }
40 else
                else
41 {
                {
42 UpperBound=curIn-1;
                    UpperBound=curIn-1;
43 }
                }
44 }
            }
45 }
        }
46 }
    }
47 
    
48 
    
49 public void Insert(long value)
    public void Insert(long value)
50 {
    {
51 int j;
        int j;
52 for(j=0;j<nElems;j++)
        for(j=0;j<nElems;j++)
53 if(a[j]>value)
            if(a[j]>value)
54 break;
                break;
55 
            
56 for(int k=nElems; k>j; k--)
            for(int k=nElems; k>j; k--)
57 {
            {
58 a[k]=a[k-1];
                a[k]=a[k-1];
59 }
            }
60 a[j]=value;
            a[j]=value;
61 nElems++;
            nElems++;
62 }
        }
63 }
    }
64 
    
65 
    
66 public boolean  delete(long  value)
    public boolean  delete(long  value)
67 {
    {
68 int j=find(value)
        int j=find(value)
69 
        
70 if(j==nElems)
        if(j==nElems)
71 return false;
            return false;
72 
        
73 else
        else
74 {
        {
75 for(int k=j;k<nElems;k++)
            for(int k=j;k<nElems;k++)
76 {
            {
77 a[k]=a[k+1];
                a[k]=a[k+1];
78 }
            }
79 nElems--;
            nElems--;
80 
            
81 return true;
            return true;
82 }
        }
83 }
    }
84 
    
85 public void display()
    public void display()
86 {
    {
87 for(int j=0;j<nElems;j++)
        for(int j=0;j<nElems;j++)
88 System.out.print(a[j]+"")
            System.out.print(a[j]+"")
89 System.out.printIn("");
        System.out.printIn("");
90 }
    }
91 }
}
92 
                    
93 
                
 class OrdArray
class OrdArray2
 {
{3
 private long[] a;
    private long[] a;4
 private  int nElems;
    private  int nElems;5
 
    6
 public OrdArray(int max)
    public OrdArray(int max)7
 {
    {8
 a=new long[max];
        a=new long[max];9
 nElems=0;
        nElems=0;10
 }
    }11
 
    12
 public int Size()
    public int Size()13
 {
    {14
 return nElems;
        return nElems;15
 }
    }16
 
    17
 public int find(long searchKey)
    public int find(long searchKey)18
 {
    {19
 int LowerBound=0;
        int LowerBound=0;20
 int UpperBound=nElems-1;
        int UpperBound=nElems-1;21
 int curIn;
        int curIn;22
 
        23
 while(true)
        while(true)24
 {
        {25
 curIn=(LowerBound+UpperBound)/2;
            curIn=(LowerBound+UpperBound)/2;26
 
            27
 if(a[curIn]==searchKey)
            if(a[curIn]==searchKey)28
 
                29
 return curIn;
             return curIn;30
 else if(LowerBound>UpperBound)
            else if(LowerBound>UpperBound)31
 
                32
 return  nElems;
            return  nElems;33
 
            34
 else
            else35
 {
            {36
 if(a[curIn]<searchKey)
                if(a[curIn]<searchKey)37
 {
                {38
 LowerBound=curIn+1;
                    LowerBound=curIn+1;39
 }
                }40
 else
                else41
 {
                {42
 UpperBound=curIn-1;
                    UpperBound=curIn-1;43
 }
                }44
 }
            }45
 }
        }46
 }
    }47
 
    48
 
    49
 public void Insert(long value)
    public void Insert(long value)50
 {
    {51
 int j;
        int j;52
 for(j=0;j<nElems;j++)
        for(j=0;j<nElems;j++)53
 if(a[j]>value)
            if(a[j]>value)54
 break;
                break;55
 
            56
 for(int k=nElems; k>j; k--)
            for(int k=nElems; k>j; k--)57
 {
            {58
 a[k]=a[k-1];
                a[k]=a[k-1];59
 }
            }60
 a[j]=value;
            a[j]=value;61
 nElems++;
            nElems++;62
 }
        }63
 }
    }64
 
    65
 
    66
 public boolean  delete(long  value)
    public boolean  delete(long  value)67
 {
    {68
 int j=find(value)
        int j=find(value)69
 
        70
 if(j==nElems)
        if(j==nElems)71
 return false;
            return false;72
 
        73
 else
        else74
 {
        {75
 for(int k=j;k<nElems;k++)
            for(int k=j;k<nElems;k++)76
 {
            {77
 a[k]=a[k+1];
                a[k]=a[k+1];78
 }
            }79
 nElems--;
            nElems--;80
 
            81
 return true;
            return true;82
 }
        }83
 }
    }84
 
    85
 public void display()
    public void display()86
 {
    {87
 for(int j=0;j<nElems;j++)
        for(int j=0;j<nElems;j++)88
 System.out.print(a[j]+"")
            System.out.print(a[j]+"")89
 System.out.printIn("");
        System.out.printIn("");90
 }
    }91
 }
}92
 
                    93
 
                 
                    
                     
                    
                 
                    
                 


 
     
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号