美文网首页
数据的快速查找

数据的快速查找

作者: linheimx | 来源:发表于2016-11-02 11:46 被阅读28次

问题

有如下一堆有序数据:


数据描述:

  1. 有序:从小到大
  2. 对每个数字进行编号:0 1 2 3

那么如何快速找到你想要的数据?

1. 数字在集合中

建议分而治之,二分查找。

2. 数字不再集合中,但要找到跟它最接近的。

建议分而治之,二分查找。
为什么要二分查找啊?

速度快啊。

代码如何实现呢?

上一个是,一个数和一个数比较。
我们现在只需要考虑,一个数和两个数相比较。

**取中间的两个数:**

看目标的数字到 两个数之间的距离情况。

  1. 离 3.6 更近,则继续处理 3.6 左边的数据。
  2. 离 5.4 更近,则继续处理 3.6 右边的数据。

代码

我的:

 public static int getEntryIndex1(List<Unit> mValues, float xValue, Rounding rounding) {

        if (mValues == null || mValues.isEmpty())
            return -1;

        int low = 0;
        int high = mValues.size() - 1;

        while (low < high) {
            int m = (low + high) / 2;

            float f1 = mValues.get(m).getX();
            float f2 = mValues.get(m + 1).getX();

            if (xValue >= f1 && xValue <= f2) {

                float d1 = Math.abs(xValue - f1);
                float d2 = Math.abs(xValue - f2);

                if (d1 <= d2) {
                    low = m;
                } else {
                    high = m + 1;
                }
                break;
                
            } else if (xValue < f1) {
                high = m;
            } else if (xValue > f2) {
                low = m;
            }
        }

        int result = low;
        if (rounding == Rounding.UP) {
            result = high;
        } else if (rounding == Rounding.DOWN || rounding == Rounding.CLOSEST) {
            result = low;
        }
        return result;
    }

MpAndroidChart:

public static int getEntryIndex(List<Unit> mValues, float xValue, Rounding rounding) {

        if (mValues == null || mValues.isEmpty())
            return -1;

        int low = 0;
        int high = mValues.size() - 1;

        while (low < high) {
            int m = (low + high) / 2;

            final float d1 = mValues.get(m).getX() - xValue,
                    d2 = mValues.get(m + 1).getX() - xValue,
                    ad1 = Math.abs(d1), ad2 = Math.abs(d2);

            if (ad2 < ad1) {
                // [m + 1] is closer to xValue
                // Search in an higher place
                low = m + 1;
            } else if (ad1 < ad2) {
                // [m] is closer to xValue
                // Search in a lower place
                high = m;
            } else {
                // We have multiple sequential x-value with same distance

                if (d1 >= 0.0) {
                    // Search in a lower place
                    high = m;
                } else if (d1 < 0.0) {
                    // Search in an higher place
                    low = m + 1;
                }
            }
        }

        if (high != -1) {
            float closestXValue = mValues.get(high).getX();
            if (rounding == Rounding.UP) {
                if (closestXValue < xValue && high < mValues.size() - 1) {
                    ++high;
                }
            } else if (rounding == Rounding.DOWN) {
                if (closestXValue > xValue && high > 0) {
                    --high;
                }
            }
        }

        return high;
    }

相关文章

  • 索引的创建与Explain的使用

    索引是帮助mysql高效获取数据的数据结构,可以简单理解为,已经排好序的用于快速查找的数据结构。排序和快速查找是关...

  • 二叉树基础下

    二叉查找树 它不仅仅支持快速查找一个数据,还支持快速插入、删除一个数据。这些都依赖于二叉查找树的特殊结构。二叉查找...

  • 二叉树下

    二叉查找树 它不仅仅支持快速查找一个数据,还支持快速插入、删除一个数据。这些都依赖于二叉查找树的特殊结构。二叉查找...

  • Swift语言实现几个简单算法

    栈队列二分查找插入排序归并排序快速排序 栈 队列 二分查找 二分查找是用于快速查找到目标数据(已排序)的一种查找方...

  • 数据的快速查找

    问题 有如下一堆有序数据: 数据描述: 有序:从小到大 对每个数字进行编号:0 1 2 3 那么如何快速找到你想要...

  • MySQL(4)应用优化

    MySQL应用优化 4.1-MySQL索引优化与设计 索引的作用 快速定位要查找的数据 数据库索引查找 全表扫描 ...

  • 索引

    排好序的快速查找数据结构 定义:数据本身之外,数据库还维护着一个满足特定查找算法的数据结构,这些数据结构以某种方式...

  • 二分查找(上):如何用最省内存的方式实现快速查找功能?

    二分查找(上):如何用最省内存的方式实现快速查找功能? 注意,二分查找(也叫折半查找)是针对有序数据集合的查找算法...

  • 跳表

    跳表:一种动态数据结构,支持快速插入、删除、查找操作。

  • Go:实现二叉搜索树(BST)

    二叉搜索树是一种支持快速查找、增加和删除元素的数据结构。二叉搜索树中的节点是有序的,因此支持快速查找。该数据结构由...

网友评论

      本文标题:数据的快速查找

      本文链接:https://www.haomeiwen.com/subject/xtevuttx.html