首页 > 其他分享 >随机查找(一切看命)

随机查找(一切看命)

时间:2023-11-01 19:15:10浏览次数:25  
标签:LeftPart return int value 查找 随机 RandomIndex 看命 dis

  对于一个给定的数组,若要查找当中是否包含某个值,传统的方法是遍历数组中的每一个元素,如果找到则返回。如果学习过数据结构,也可以立马想到用哈希表来存储,哈希表的查找性能优异,一般可以达到O(1)的时间复杂度,在最坏情况下也有可能达到O(n)的复杂度。但是今天,我将带来一种有意思的查找方式,也就是通过随机数来对数组进行划分。这种方式运用到了分治的思想,每次随机生成一个下标,然后判断该下标的元素是否等于目标值,如果不等于,则对该下标两边的元素进行递归查找,之后每一次划分的下标也是基于随机数生成。说起来比较抽象,我们来看看代码。

bool RandomFind(const std::vector<int>& v, int l, int r, const int& value) {
    if (l > r)
        return false;
    if (l == r) {
        if (v[l] == value)
            return true;
        return false;
    }

    std::uniform_int_distribution dis(l, r);
    int RandomIndex = dis(g);

    bool LeftPart = RandomFind(v, 0, RandomIndex, value);
    bool RightPart = RandomFind(v, RandomIndex + 1, r, value);

    return LeftPart || RightPart;
}

  注意递归的终止条件,需要防止数组最小下标l大于最大的下标,还要注意处理好数组只剩下一个元素的情况。由于我们只需要判断是否找到某个元素,因此LeftPart和RightPart只需要有其中一部分找到即可。不过我们还可以对上述代码进行一定的“剪枝”优化,换句话说就是如果随机生成的下标对应的元素是目标值,我们直接return,没必要再做无意义的搜索了。对上面代码稍作改动即可。

bool RandomFind(const std::vector<int>& v, int l, int r, const int& value) {
    if (l > r)
        return false;
    if (l == r) {
        if (v[l] == value)
            return true;
        return false;
    }

    std::uniform_int_distribution dis(l, r);
    int RandomIndex = dis(g);
    if (v[RandomIndex] == value)
        return true;

    bool LeftPart = RandomFind(v, 0, RandomIndex - 1, value);
    bool RightPart = RandomFind(v, RandomIndex + 1, r, value);

    return LeftPart || RightPart;
}

  贴个Python版的。

import random 

def randomFind(v: list, l: int, r: int, target: int) -> bool:
    if l > r:
        return False
    if l == r:
        if v[l] == target:
            return True
        return False

    dis = random.randint(l, r)
    if v[dis] == target:
        return True 
    
    LeftPart = randomFind(v, 0, dis - 1, target)
    RightPart = randomFind(v, dis + 1, r, target)

    return LeftPart or RightPart

  不过话说回来,这种查找方式容易递归较深,性能也不高,仅仅当随机生成的下标对应的元素刚好等于目标值的时候可能稍微快点,所以说一切看命。

标签:LeftPart,return,int,value,查找,随机,RandomIndex,看命,dis
From: https://www.cnblogs.com/ChebyshevTST/p/17802574.html

相关文章

  • 如何在excel中查找问号“?”星号“*”和“~”号
    Excel查找替换时如何使用通配符的问号? 若需要查找问号“?”,则在查找内容文本框中输入“~?”若需要查找星号“*”,则在查找内容文本框中输入“~*”。若需要查找问号“~”,则在查找内容文本框中输入“~~”。......
  • 数据结构——二分查找(1)
    ``点击查看代码importjava.util.Scanner;publicclassMain{publicstaticint[]a=newint[10];publicstaticvoidmain(String[]args){Scanners=newScanner(System.in);intn=s.nextInt();intb......
  • 二分查找算法题1
    /***https://leetcode.cn/problems/sqrtx/description/*二分查找*将数据分成两部分*第一部分为平方小于等于target*另外的为大于target*left=mid。right=mid-1;使用+1求中**/publicstaticvoidhanShu19(intx){......
  • 【动画进阶】单标签下多色块随机文字随机颜色动画
    我的小册 《CSS技术揭秘与实战通关》上线了,想了解更多有趣、进阶、系统化的CSS内容,可以猛击- LINK。在CSS还原拉斯维加斯球数字动画-掘金一文中,我们利用纯CSS,实现了一个非常Amazing的动画效果:其中一个核心点就是,我们利用了如下的代码,在一个DIV平面内,实现了单......
  • 如何基于通配符匹配在当前目录及其子目录中递归查找所有文件?
    内容来自DOChttps://q.houxu6.top/?s=如何基于通配符匹配在当前目录及其子目录中递归查找所有文件?如何基于通配符匹配在当前目录及其子目录中递归查找所有文件?使用find(Linux命令):find.-name"foo\*"find需要一个起始点,因此.(点)指向当前目录。......
  • 记一次自增主键id换为随机id
    原始表自增主键为Long类型为了不影响原有逻辑使用触发器新建mysql触发器DROPTRIGGERIFEXISTS`insert_trigger`;DELIMITER//CREATETRIGGERinsert_triggerBEFOREINSERTONuserFOREACHROWBEGINDECLAREnew_idINT;DECLAREtemp_idINT;SETnew_id=FLOOR(RA......
  • UE5 怎么快速查找 UI 是哪个蓝图?
    通过“工具”->"调试"->"控件反射器"官方文档:https://docs.unrealengine.com/5.1/zh-CN/using-the-slate-widget-reflector-in-unreal-engine/......
  • super的查找顺序严格按照mro列表找
    调用父类方法的第一种方式:指名道姓的方式,跟继承关无关#object写与不写,在py3中没有区别.#有的人在py3中这么写,是为了向下兼容,使复制到py2中也能使用classPerson(object):def__init__(self,name,age):self.name=nameself.age=agedefi......
  • 二分查找模版
    给定一个有序数组nums,求数组中第一个>=目标值target的下标位置和最后一个>=目标值target的下标位置。这是一道基础的二分查找问题,关于二分的写法有很多种,难点在于对于二分边界的处理,代码编写的过程中很容易容易出现死循环问题,因此建议套用现成的一些二分模版,关于二分模版网上有很......
  • 用C语言,查找和判断年份是否为闰年
    今天我们来探讨一下用C程序代码来判断一个年份是否为闰年,或者题目给定一个年份区间,来查询里面有那些年份属于闰年:闰年的判断条件:1.能被4整除,但不能被100整除2.能被400整除运行结果如下:代码如下:#include<stdio.h>//打印1000到2000之间的闰年//闰年的判断条件:1.能被4整除,但不能被10......