2.16给定一个无穷数组A[.],其中前n个元素都是整数,且已经排好序,剩余元素均为∞。n的值未知。给出一个算法,以一个整数x为输入,以O(logn)时间找到数组中的一个位置,并满足其上的元素为x。

题目二:

2.16给定一个无穷数组A[.],其中前n个元素都是整数,且已经排好序,剩余元素均为∞。n的值未知。给出一个算法,以一个整数x为输入,以O(logn)时间找到数组中的一个位置,并满足其上的元素为x。

算法思想:

从题目所给时间复杂度开始思考,结合题目要求是查找算法,自然想到二分查找,时间复杂度为O(logn),但此题并未告知数组长度,所以要确定二分查找的范围,如果用循环遍历,则需要O(n)时间,O(n)+O(logn)=O(n),不满足题目所需,所以这里在遍历时采用i2=i代替i++进行遍历,这样时间复杂度就由O(n)降为O(logn),具体来说找上限时就是X与A[i]比较,若X大,则X再与A[i2]比较,找下限时同理与A[i/2]比较。找到范围后采用二分查找即可。时间复杂度为O(logn)+O(logn)=O(logn)。**

代码:

#include <iostream>
#include <vector>
#include <math.h>
#define INFINITY 1000000
using namespace std;
int BiSearch(vector<int>&A, int low, int high, int k)
{
    if (low > high)
        return -1;
    else
    {
        int mid = (low + high) / 2;
        if (A[mid] == k)
            return mid;
        else
        {
            if (A[mid] < k)
                return BiSearch(A, mid + 1, high, k);
            else
                return BiSearch(A, low, mid - 1, k);
        }
    }
}
int main(void)
{
    vector<int>A(INFINITY, INFINITY);
    int n = 100;
    for (int i = n; i > 0; i--)
    {
        A.insert(A.begin(), i);
    }
    int x;
    cin >> x;
    if (x == A[0])
        cout << "位置为0";
    else
    {
        int fre_high = 0,fre_low=0,i=1;
        while (i>=1)
        {
            if (x > A[i])
            {
                i *= 2;
                fre_high++;
            }
            fre_low = fre_high;
            if (x < A[i])
            {
                i /= 2;
                fre_low--;
            }
            if (x >= A[pow(2, fre_low)] && x <= A[pow(2, fre_high)])
            {
                break;
            }
        }
        if (i == 0)
            cout << "x不在序列中";
        else
            cout<<"位置为:"<<BiSearch(A, pow(2, fre_low), pow(2, fre_high), x);
    }
    system("pause");
    return 0;
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一些概念 数据结构就是研究数据的逻辑结构和物理结构以及它们之间相互关系,并对这种结构定义相应的运算,而且确保经过这...
    Winterfell_Z阅读 6,067评论 0 13
  • 1. 找出数组中重复的数字 题目:在一个长度为n的数组里的所有数字都在0到n-1的范围内。数组中某些数字是重复的,...
    BookThief阅读 1,836评论 0 2
  • 前言 2. 实现 Singleton 3. 数组中重复的数字 4. 二维数组中的查找 5. 替换空格 6. 从尾到...
    Observer_____阅读 3,022评论 0 1
  • 我丢失了你,在这迷离的灯火中,在这一个喝醉的城。 车流行进不已,不肯停下,再无人告诉我哪里是归途,哪里是沼泽,它们...
    伊俩特阅读 120评论 0 1
  • 海底月是天上月,眼前人是有缘人 以前听人说人的一生会遇见2162万人,有的只是擦肩而过,有的不经意间的善意就会让我...
    啦啦啦取什么好呢阅读 169评论 2 0