• Java数组排序和搜索


    如何排序数组并搜索其中的元素?

    以下示例显示如何使用sort()binarySearch()方法来完成任务。用户定义的方法printArray()用于显示数组输出:

    package com.yiibai;
    
    import java.util.Arrays;
    
    public class ArraySortAndSearch {
        public static void main(String args[]) throws Exception {
            int array[] = { 2, 5, -2, 6, -3, 8, 0, -7, -9, 4 };
            Arrays.sort(array);
            printArray("Sorted array", array);
            int index = Arrays.binarySearch(array, 2);
            System.out.println("Found 2 @ " + index);
        }
    
        private static void printArray(String message, int array[]) {
            System.out.println(message + ": [length: " + array.length + "]");
    
            for (int i = 0; i < array.length; i++) {
                if (i != 0) {
                    System.out.print(", ");
                }
                System.out.print(array[i]);
            }
            System.out.println();
        }
    }
    
    Java

    执行上面示例代码,得到以下结果 -

    Sorted array: [length: 10]
    -9, -7, -3, -2, 0, 2, 4, 5, 6, 8
    Found 2 @ 5
    
    Shell

    线性搜索

    以下示例显示使用线性搜索的搜索数组元素。

    package com.yiibai;
    
    public class ArraySortAndSearch2 {
        public static void main(String[] args) {
            int[] a = { 2, 5, -2, 6, -3, 8, 0, -7, -9, 4 };
            int target = 0;
    
            for (int i = 0; i < a.length; i++) {
                if (a[i] == target) {
                    System.out.println("Element found at index " + i);
                    break;
                }
            }
        }
    }
    
    Java

    执行上面示例代码,得到以下结果 -

    Element found at index 6
    
    Shell

    冒泡排序

    以下示例显示使用冒泡排序方法来排序数组元素。

    package com.yiibai;
    
    public class ArraySortAndSearch3 {
        static void bubbleSort(int[] arr) {
            int n = arr.length;
            int temp = 0;
            for (int i = 0; i < n; i++) {
                for (int j = 1; j < (n - i); j++) {
                    if (arr[j - 1] > arr[j]) {
                        temp = arr[j - 1];
                        arr[j - 1] = arr[j];
                        arr[j] = temp;
                    }
                }
            }
        }
    
        public static void main(String[] args) {
            int arr[] = { 2, 5, -2, 6, -3, 8, 0, -7, -9, 4 };
            System.out.println("Array Before Bubble Sort");
    
            for (int i = 0; i < arr.length; i++) {
                System.out.print(arr[i] + " ");
            }
            System.out.println();
            bubbleSort(arr);
            System.out.println("Array After Bubble Sort");
    
            for (int i = 0; i < arr.length; i++) {
                System.out.print(arr[i] + " ");
            }
        }
    }
    
    Java

    执行上面示例代码,得到以下结果 -

    Array Before Bubble Sort
    2 5 -2 6 -3 8 0 -7 -9 4 
    Array After Bubble Sort
    -9 -7 -3 -2 0 2 4 5 6 8
  • 相关阅读:
    Android真机测试、乐视手机启用开发者模式
    HTML5 Geolocation API地理定位整理(二)
    HTML5 Geolocation API地理定位整理(一)
    HTML5 Geolocation API工作原理[转载]
    HTML5 filesystem: 网址
    RequireJS API
    Grunt 之 watch 和 livereload
    Grunt 之通配符
    前端开发 Grunt 之 Connect
    创建 Web 前端开发环境
  • 原文地址:https://www.cnblogs.com/borter/p/9612999.html
Copyright © 2020-2023  润新知