在一个基本有序的数组中查询指定元素

原创 2017年01月03日 10:56:03

一个数组中的元素是基本有序的,意思就是说当遇到次序打乱的元素的时候,它与自己有序的正确位置只能是前后相邻的位置,比如数组:


arr=[1,2,3,4,5,7,6,8,9,10]

这个数组6前面相邻的7调换一下就称为一个有序的数组。

如果一个数组完全有序,那么我们可以用二分查找法很快找到指定的元素,但是现在是基本有序,那还能不能用二分查找法呢,答案是可以的,不过得稍稍改一下。

我们已经直到了一个数组基本有序的意思是讲,即使出现乱序的情况,只要在前后相邻位置做恰当地调整,就能够调为有序,也就是说局部无序的元素长度不超过2,有了这个条件那就简单多了,我们仍然用二分查找法,无非不过是需要多一个比对一下相邻元素的情况这一步骤罢了:

public class SearchAlmost {
    // A recursive binary search based function. It returns index of x in given array arr[l..r] is present, otherwise -1
    public static int binarySearch(int arr[], int l, int r, int x) {
        if (r >= l) {
            int mid = l + (r - l) / 2;

            // If the element is present at one of the middle 3 positions
            if (arr[mid] == x) return mid;
            if (mid > l && arr[mid - 1] == x) return (mid - 1);
            if (mid < r && arr[mid + 1] == x) return (mid + 1);

            // If element is smaller than mid, then it can only be present in left subarray
            if (arr[mid] > x) return binarySearch(arr, l, mid - 2, x);

            // Else the element can only be present in right subarray
            return binarySearch(arr, mid + 2, r, x);
        }

        // We reach here when element is not present in array
        return -1;
    }

    public static void main(String args[]) {
        int arr[] = {3, 2, 10, 4, 40};
        int n = arr.length;
        int x = 4;
        int result = binarySearch(arr, 0, n - 1, x);
        if (result == -1)
            System.out.println("Element is not present in array");
        else
            System.out.println("Element is present at index " + result);
    }
}

该算法的时间复杂度仍为O(logn),这比横向扫描一遍的时间复杂度O(n)强点。

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

给定A, B两个整数,不使用除法和取模运算,求A/B的商和余数

给定A, B两个整数,不使用除法和取模运算,求A/B的商和余数。 1.   最基本的算法是,从小到大遍历: for (i = 2 to A -1)          if (i * B > A)...

利用K-means聚类算法根据经纬度坐标对中国省市进行聚类

K-means聚类算法是一种非层次聚类算法,在最小误差的基础上将数据划分了特定的类,类间利用距离作为相似度指标,两个向量之间的距离越小,其相似度就越高。程序读取全国省市经纬度坐标,然后根据经纬度坐标进...

Radon变换理论介绍与matlab实现--经验交流

本人最近在研究Radon变换,在查阅了各种资料之后在此写下个人的理解,希望与各位牛牛进行交流共同进步,也使得理解更加深刻些。 Radon变换的本质是将原来的函数做了一个空间转换,即,将原来的XY平...

Matlab绘图-很详细,很全面

Matlab绘图强大的绘图功能是Matlab的特点之一,Matlab提供了一系列的绘图函数,用户不需要过多的考虑绘图的细节,只需要给出一些基本参数就能得到所需图形,这类函数称为高层绘图函数。此外,Ma...

CT图像重建技术

由于csdn贴图不方便,并且不能上传附件,我把原文上传到了资源空间CT图像重建技术 1.引言 计算机层析成像(Computed Tomography,CT)是通过对物体进行不同角度的射线投影测量而...

linux查找目录下的所有文件中是否含有某个字符串

查找目录下的所有文件中是否含有某个字符串  find .|xargs grep -ri "IBM"  查找目录下的所有文件中是否含有某个字符串,并且只打印出文件名  find .|xargs g...

Radon变换入门matlab CT原理

http://hi.baidu.com/hi9394/blog/item/0d492b8bfd714700c8fc7aa9.html 简介 图像投影,就是说将图像在某一方向上做线性积分(或理解为累...

Intel系列处理器的三种工作模式

Intel系列处理器的三种工作模式 微机中常用的Intel系列微处理器的主要发展过程是:8080,8086/8088,80186, 80286,80386,80486,Pentium,Pen...

js弹出框、对话框、提示框、弹窗总结

js弹出框、对话框、提示框、弹窗总结 一、JS的三种最常见的对话框 [javascript] view plaincopy //=...

form表单的两种提交方式,submit和button的用法

1.当输入用户名和密码为空的时候,需要判断。这时候就用到了校验用户名和密码,这个需要在jsp的前端页面写;有两种方法,一种是用submit提交。一种是用button提交。 方法一: 在jsp的...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在一个基本有序的数组中查询指定元素
举报原因:
原因补充:

(最多只允许输入30个字)