---恢复内容开始--- class ArrayTest3 { public static void main(String[] args) { //int [] arr=new int[]{54,45,6,5,34,656,34,2}; //int index=GetIndex(arr,2); //System.out.println("index="+index); int [] arr1=new int[]{2,4,5,7,12,34,35,46,67,89,99}; int i
1.顺序查找 从数组起始扫描到数组结尾,判断该索引数组是否和关键字相等,成功返回1 代码如下: //顺序查找 int seqSearch(int *array, int low, int high, int key) { for (int i = low; i < high; i++) { if (array[i] == key) return i; } ; } 2.折半查找 适用于有序数组 不停地抛弃掉一半的结点,例子如下 我们要查找key=4的结点,获取中间值mid,mid=(low+hig
折半查找,也称二分查找.二分搜索,是一种在有序数组中查找某一特定元素的搜索算法. 搜素过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束:如果某一特定元素大于或者小于中间元素,则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较. 如果在某一步骤数组已经为空,则表示找不到指定的元素.这种搜索算法每一次比较都使搜索范围缩小一半,其时间复杂度是 O(logN). import java.util.Comparator; public class MyUti
#include <stdio.h>#include <time.h> #define CLOCKS_PER_SEC ((clock_t)1000) int binsearch(int, int array[], int n); int main(){ int array[] = {2, 5, 6, 8, 9, 11, 12, 13, 14, 15, 16}; int tag = 9; int res = -1; clock_t start; clock_t finish; sta