学了数组之后,感觉有好多操作需要经常去写,很不方便,因此自己做了一个工具类,方便调用,方法可能不全,希望大家可以添加,让我使用也方便一点儿。

  1 public class ArrayUtils {
  2 //求数组的最大值(int)
  3     public static int getMax(int[] arr){
  4         int max = arr[0];
  5         for(int i = 0;i<arr.length;i++){
  6             if(max<arr[i]){
  7                 max = arr[i];
  8             }
  9         }
 10         return max;
 11     }
 12 //求数组的最小值(int)
 13     public static int getMin(int[] arr){
 14         int min = arr[0];
 15         for(int i = 0;i<arr.length;i++){
 16             if(min>arr[i]){
 17                 min = arr[i];
 18             }
 19         }
 20         return min;
 21     }
 22 //得到数组最大值的下标(int)
 23     public static int getMaxIndex(int[] arr){
 24         int maxIndex = 0;
 25         for(int i = 0;i <arr.length;i++){
 26             if(arr[maxIndex]<arr[i]){
 27                 maxIndex = i;
 28             }
 29         }
 30         return maxIndex;
 31     }
 32 //得到数组最小值的下标(int)
 33     public static int getMinIndex(int[] arr){
 34         int minIndex = 0;
 35         for(int i = 0;i <arr.length;i++){
 36             if(arr[minIndex]>arr[i]){
 37                 minIndex = i;
 38             }
 39         }
 40         return minIndex;
 41     }
 42 //获得数组之和(int)
 43     public static int getSum(int[] arr){
 44         int sum = 0;
 45         for(int i = 0; i < arr.length;i++){
 46             sum += arr[i];
 47         }
 48         return sum;    
 49     }
 50 //获得平均值(int)
 51     public static int getAverage(int[] arr){
 52         int avg = getSum(arr)/arr.length;
 53         return avg;
 54     }
 55 //打印数组(int)
 56     public static void printArray(int[] arr){
 57         for(int i = 0;i<arr.length;i++){
 58             if(i!=arr.length-1){
 59                 System.out.print(arr[i]+",");
 60             }else{
 61                 System.out.println(arr[i]);
 62             }
 63         }
 64     }
 65 //选择排序对数据进行降序排序(int)
 66             public static void selectSortDescendingArray(int[] arr){
 67                 for(int i = 0; i<arr.length-1;i++){//i<arr.length-1;最后一个不用比较
 68                     for(int j = i+1;j<arr.length;j++){
 69                         if(arr[i]<arr[j]){
 70                             int temp = arr[j];
 71                             arr[j] = arr[i];
 72                             arr[i] = temp;
 73                          }
 74                     }
 75                 }
 76             }
 77 //选择排序对数据进行升序排序(int)
 78             public static void selectSortAscendingArray(int[] arr){
 79                 for(int i = 0; i<arr.length-1;i++){//i<arr.length-1;最后一个不用比较
 80                     for(int j = i+1;j<arr.length;j++){
 81                         if(arr[i]>arr[j]){
 82                             int temp = arr[j];
 83                             arr[j] = arr[i];
 84                             arr[i] = temp;
 85                          }
 86                     }
 87                 }
 88             }
 89 //冒泡排序对数据进行降序排序(int)
 90         public static void bubbleSortDescendingArray(int[] arr){
 91             for(int i = 0;i<arr.length-1;i++){
 92                 for(int j = 0;j<arr.length-1-i;j++){
 93                     if(arr[j]<arr[j+1]){
 94                         int temp = arr[j+1];
 95                         arr[j+1] = arr[j];
 96                         arr[j] = temp;
 97                         }
 98                 }
 99             }
100         }
101 //冒泡排序对数据进行升序排序(int)
102         public static void bubbleSortAscendingArray(int[] arr){
103             for(int i = 0;i<arr.length-1;i++){
104                 for(int j = 0;j<arr.length-1-i;j++){
105                     if(arr[j]>arr[j+1]){
106                         int temp = arr[j+1];
107                         arr[j+1] = arr[j];
108                         arr[j] = temp;
109                         }
110                 }
111             }
112         }
113 //二分查找(int)
114         public static int binarySearch(int[] arr,int key){
115             int min,mid,max;
116             min = 0;
117             max = arr.length-1;
118             while(arr[min]<arr[max]){
119                 mid = (min+max)/2;
120                 if(key>arr[mid]){
121                     min = mid+1;
122                 }else if(key<arr[mid]){
123                     max = mid-1;
124                 }else {
125                     return mid;
126                 }
127             }
128             return -1;
129         }
130 //*********************************************************************
131         
132 //求数组的最大值(double)
133     public static double getMax(double[] arr){
134         double max = arr[0];
135         for(int i = 0;i<arr.length;i++){
136             if(max<arr[i]){
137                 max = arr[i];
138             }
139         }
140         return max;
141     }
142 //求数组的最小值(double)
143         public static double getMin(double[] arr){
144             double min = arr[0];
145             for(int i = 0;i<arr.length;i++){
146                 if(min>arr[i]){
147                     min = arr[i];
148                 }
149             }
150             return min;
151         }
152 //得到数组最大值的下标(double)
153         public static int getMaxIndex(double[] arr){
154             int maxIndex = 0;
155             for(int i = 0;i <arr.length;i++){
156                 if(arr[maxIndex]<arr[i]){
157                     maxIndex = i;
158                 }
159             }
160             return maxIndex;
161         }
162 //得到数组最小值的下标(double)
163         public static int getMinIndex(double[] arr){
164             int minIndex = 0;
165             for(int i = 0;i <arr.length;i++){
166                 if(arr[minIndex]>arr[i]){
167                     minIndex = i;
168                 }
169             }
170             return minIndex;
171         }
172 //获得数组之和(double)
173         public static double getSum(double[] arr){
174             double sum = 0;
175             for(int i = 0; i < arr.length;i++){
176                 sum += arr[i];
177             }
178             return sum;    
179         }
180 //获得平均值(double)
181         public static double getAverage(double[] arr){
182             double avg = getSum(arr)/arr.length;
183             return avg;
184         }
185 //打印数组(double)
186                 public static void printArray(double[] arr){
187                     for(int i = 0;i<arr.length;i++){
188                         if(i!=arr.length-1){
189                             System.out.print(arr[i]+",");
190                         }else{
191                             System.out.println(arr[i]);
192                         }
193                     }
194                 }
195 //选择排序对数据进行降序排序(double)
196         public static void selectSortDescendingArray(double[] arr){
197             for(int i = 0; i<arr.length-1;i++){//i<arr.length-1;最后一个不用比较
198                 for(int j = i+1;j<arr.length;j++){
199                     if(arr[i]<arr[j]){
200                         double temp = arr[j];
201                         arr[j] = arr[i];
202                         arr[i] = temp;
203                      }
204                 }
205             }
206         }
207 //选择排序对数据进行升序排序(double)
208         public static void selectSortAscendingArray(double[] arr){
209             for(int i = 0; i<arr.length-1;i++){//i<arr.length-1;最后一个不用比较
210                 for(int j = i+1;j<arr.length;j++){
211                     if(arr[i]>arr[j]){
212                         double temp = arr[j];
213                         arr[j] = arr[i];
214                         arr[i] = temp;
215                      }
216                 }
217             }
218         }
219 //冒泡排序对数据进行降序排序(double)
220     public static void bubbleSortDescendingArray(double[] arr){
221         for(int i = 0;i<arr.length-1;i++){
222             for(int j = 0;j<arr.length-1-i;j++){
223                 if(arr[j]<arr[j+1]){
224                     double temp = arr[j+1];
225                     arr[j+1] = arr[j];
226                     arr[j] = temp;
227                     }
228             }
229         }
230     }
231 //冒泡排序对数据进行升序排序(double)
232     public static void bubbleSortAscendingArray(double[] arr){
233         for(int i = 0;i<arr.length-1;i++){
234             for(int j = 0;j<arr.length-1-i;j++){
235                 if(arr[j]>arr[j+1]){
236                     double temp = arr[j+1];
237                     arr[j+1] = arr[j];
238                     arr[j] = temp;
239                     }
240             }
241         }
242     }
243 //二分查找(double)
244             public static int binarySearch(double[] arr,double key){
245                 int min,mid,max;
246                 min = 0;
247                 max = arr.length-1;
248                 while(arr[min]<arr[max]){
249                     mid = (min+max)/2;
250                     if(key>arr[mid]){
251                         min = mid+1;
252                     }else if(key<arr[mid]){
253                         max = mid-1;
254                     }else {
255                         return mid;
256                     }
257                 }
258                 return -1;
259             }
260 
261 }