网站建设伍金手指下拉7网站建设专业可行性分析

web/2025/10/2 16:10:00/文章来源:
网站建设伍金手指下拉7,网站建设专业可行性分析,热门软件排行榜,最好国内免费网站空间1.什么是位图 所谓位图#xff0c;就是用每一位来存放某种状态#xff0c;适用于海量数据#xff0c;数据无重复的场景。通常是用来判断某个数据存不存在的。比如int 有32位#xff0c;就可以存放0到31这32个数字在不在某个文件中。当然#xff0c;其他类型也可以。 2.位…1.什么是位图 所谓位图就是用每一位来存放某种状态适用于海量数据数据无重复的场景。通常是用来判断某个数据存不存在的。比如int 有32位就可以存放0到31这32个数字在不在某个文件中。当然其他类型也可以。 2.位图的应用 快速查找某个数据是否在一个集合中排序 去重求两个集合的交集、并集等操作系统中磁盘块标记 2.1 实际使用场景 1.给40亿个不重复的无符号整数没排过序。给一个无符号整数如何快速判断一个数是否在这40亿个数中。 由于有40亿个数字40亿个int的大小为16G如果放在内存中是开销是非常大的只能使用位图来解决因为一个int可以放32个数据int的大小为4字节32比特位40亿整数的大小大约为512MB,完全可以存放下。 位图解决思路数据是否在给定的整形数据中结果是在或者不在刚好是两种状态那么可以使用一个二进制比特位来代表数据是否存在的信息如果二进制比特位为1代表存在为0代表不存在。比如 通过这样的运算即可在使用较少的内存的情况下来快速判断某个数字是否存在。 2.给定100亿个整数设计算法找到只出现一次的整数 由于有100亿个整数所以一定会有重复出现的整数因为int的最大值大约为42亿。 寻找一个数字可以使用两个位图一个为0另一个为1。来判断是否出现一次因为00为没有出现的次数01为出现一次的个数10为出现2次及2次以上的个数。如图· 3.给两个文件分别有100亿个整数我们只有1G内存如何找到两个文件交集 100亿个·整数1G内存这道题和上一道题差不多依然使用两各位图用来存储在或不在的情况将一个文件的整数放在一个位图中遍历另一个文件然后判断如果两个都为1则存在然后将这个数字所在的位置置为0因为判断交集只用考虑在或不在不用考虑个数。 4.1个文件有100亿个int1G内存设计算法找到出现次数不超过2次的所有整数 方法和上一道题一样解法参见上一道题 3.位图的实现 //位图templatesize_t Nclass bitset//判断一个数字是否存在{public://初始化bitset(){_bis.resize(N / 32 1,0);}//把X位标记为1void set(const size_t x){size_t i x / 32;size_t j x % 32;_bis[i] | (1 j);//并}//把X位标记为0,即删除该数字void reset(const size_t x){size_t i x / 32;size_t j x % 32;_bis[i] (~(1 j));//与}//判断是否存在bool test(const size_t x){size_t i x / 32;size_t j x % 32;return _bis[i] (1 j);}private:vectorint _bis;};//判断出现0次,1次,2次以上templatesize_t Nclass twonbits{public:void set(const size_t x){if (!_bits.test(x) !_bitss.test(x))// 0 0变为 0 1{_bitss.set(x);//出现一次}else if (!_bits.test(x) _bitss.test(x))// 0 1 变为 1 0{_bits.set(x);_bitss.reset(x);//出现两次}else if (_bits.test(x) !_bitss.test(x))// 1 0变为1 1{_bits.set(x);_bitss.set(x);//出现三次}}//判断出现一次的数字,即01bool is_once(const size_t x){return !_bits.test(x) _bitss.test(x);}//出现两次即10bool is_twice(const size_t x){return _bits.test(x) !_bitss.test(x);}//出现三次以上的即11以上的bool is_ThreeTimes(const size_t x){return _bits.test(x) _bitss.test(x);}private:bitsetN _bits;bitsetN _bitss;}; 4.什么是布隆过滤器 我们在使用新闻客户端看新闻时它会给我们不停地推荐新的内容它每次推荐时要去重去掉那些已经看过的内容。问题来了新闻客户端推荐系统如何实现推送去重的 用服务器记录了用户看过的所有历史记录当推荐系统推荐新闻时会从每个用户的历史记录里进行筛选过滤掉那些已经存在的记录。 如何快速查找呢 1. 用哈希表存储用户记录缺点浪费空间 2. 用位图存储用户记录缺点位图一般只能处理整形如果内容编号是字符串就无法处理了。 3. 将哈希与位图结合即布隆过滤器。 布隆过滤器特点是高效地插入和查询可以用来告诉你 “某样东西一定不存在或者可能存在”它是用多个哈希函数将一个数据映射到位图结构中。此种方式不仅可以提升查询效率也可以节省大量的内存空间。 5.布隆过滤器的查找 布隆过滤器的思想是将一个元素用多个哈希函数映射到一个位图中因此被映射到的位置的比特位一定为1。所以可以按照以下方式进行查找分别计算每个哈希值对应的比特位置存储的是否为零只要有一个为零代表该元素一定不在哈希表中否则可能在哈希表中。 注意布隆过滤器如果说某个元素不存在时该元素一定不存在如果该元素存在时该元素可能存在因为有些哈希函数存在一定的误判。 比如在布隆过滤器中查找alibaba时假设3个哈希函数计算的哈希值为1、3、7刚好和其他元素的比特位重叠此时布隆过滤器告诉该元素存在但实该元素是不存在的。 所以布隆过滤器判断不在是准确的判断在是不准确的。 6.布隆过滤器删除 布隆过滤器不能直接支持删除工作因为在删除一个元素时可能会影响其他元素。 比如删除tencent元素如果直接将该元素所对应的二进制比特位置0可能“baidu”元素也被删除了因为这两个元素在多个哈希函数计算出的比特位上刚好有重叠。 一种支持删除的方法将布隆过滤器中的每个比特位扩展成一个小的计数器插入元素时给k个计数器(k个哈希函数计算出的哈希地址)加一删除元素时给k个计数器减一通过多占用几倍存储空间的代价来增加删除操作。 缺陷 1. 无法确认元素是否真正在布隆过滤器中 2. 存在计数回绕 7.布隆过滤器的优缺点 优点 1. 增加和查询元素的时间复杂度为:O(K), (K为哈希函数的个数一般比较小)与数据量大小无关 2. 哈希函数相互之间没有关系方便硬件并行运算 3. 布隆过滤器不需要存储元素本身在某些对保密要求比较严格的场合有很大优势 4. 在能够承受一定的误判时布隆过滤器比其他数据结构有这很大的空间优势 5. 数据量很大时布隆过滤器可以表示全集其他数据结构不能 6. 使用同一组散列函数的布隆过滤器可以进行交、并、差运算 缺点 1. 有误判率即存在假阳性(False Position)即不能准确判断元素是否在集合中(补救方法再建立一个白名单存储可能会误判的数据) 2. 不能获取元素本身 3. 一般情况下不能从布隆过滤器中删除元素 4. 如果采用计数方式删除可能会存在计数回绕问题 8.布隆过滤器应用场景 1.给两个文件分别有100亿个query我们只有1G内存如何找到两个文件交集分别给出精确算法和近似算法 近似算法就是使用布隆过滤器将两个文件存放在位图中寻找交集。 精细算法 由于有100一个query,假设一个query30字节,所以100亿个query大约300G两个文件600G的大小我们可以利用哈希切分将每个文件分为1000分小文件注意1000份不是平均分的然后将文件Ai放在set中再在文件Bi找如果在就是交集然后删除交集找到Ai和Bi的交集但是在不是平均分的情况下有可能导致其中某个文件体积过于庞大导致内存不够存放导致这种原因的有两种情况 1.大部分都是相同的少部分由于哈希冲突导致的 2.大部分都是由于哈希冲突导致的少部分是相同的 解决的方法是将文件Ai放入set里面判断set的insert出现bad_alloc,说明是由于哈希冲突导致的可以更换哈希函数重新分配一边如果没有出现bad_alloc,则存在大量重复相同元素使用set之后将重复元素去掉。然后求交集。 2.给一个超过100G大小的log file, log中存着IP地址, 设计算法找到出现次数最多的IP地址 可以使用哈希切分将100G大小的文件平均分为1000个文件然后将在这1000份文件中使用map计算相同文件的ip地址算出最多的IP地址。 9.布隆过滤器的实现 //布隆过滤器templateclass K,size_t Nclass BloomFilter{private://哈希函数防止哈希冲突struct BKDRHash{size_t operator()(const string str){size_t hash 0;for (auto ch : str){hash hash * 131 ch;}//cout BKDRHash: hash endl;return hash;}};struct APHash{size_t operator()(const string str){size_t hash 0;for (size_t i 0; i str.size(); i){size_t ch str[i];if ((i 1) 0){hash ^ ((hash 7) ^ ch ^ (hash 3));}else{hash ^ (~((hash 11) ^ ch ^ (hash 5)));}}//cout APHash: hash endl;return hash;}};struct DJBHash{size_t operator()(const string str){size_t hash 5381;for (auto ch : str){hash (hash 5) ch;}//cout DJBHash: hash endl;return hash;}};public://是否存在不准确判断不在准确//templateclass Kvoid set(const K key){size_t hash1 BKDRHash()(key) % N;_bs.set(hash1);size_t hash2 APHash()(key) % N;_bs.set(hash2);size_t hash3 DJBHash()(key) % N;_bs.set(hash3);}//判断是否存在//templateclass Kbool test(const K key){size_t hash1 BKDRHash()(key) % N;if (_bs.test(hash1) false)return false;size_t hash2 APHash()(key) % N;if (_bs.test(hash2) false)return false;size_t hash3 DJBHash()(key) % N;if (_bs.test(hash3) false)return false;return true; // 三个都在即在}private:bitsetN _bs;};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/85701.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

成功案例网站建设怎么自己做网站吗

前言 日常开发中常会使用redis作为项目中的缓存,只要我们使用 Redis 缓存,就必然会面对缓存和数据库间的一致性保证问题。而且如果数据不一致,那么应用从缓存中读取的数据就不是最新数据,可能会导致严重的业务问题。 为什么会数…

电子商务网站建设系统功能梅州南站

这个视频flash上传及在线播放,搞了我一天了,总算有点成果,但还有一些疑问没有解决,现在发这篇随笔,为的就是交流视频在线上传和观看的一些问题。 在线编辑器使用FCKEditor,首先是修改FCKEditor的配置文件&a…

电子商务网站建设考纲网站建设 10万元

提到降噪强度(denoising strength),大家一定不会陌生,这个参数是图生图中最关键的参数之一。今天在Stable Diffusion Art网站看到一篇介绍降噪强度(denoising strength)的文章(地址:…

多国语言外贸网站模板上海建设网站哪家好

1.索引 1.1创建索引: create index 索引名称 on 某张表 (列名) 示例: create index index_name on table (Column names) 1.2索引优化 MySQL数据库索引优化是提高查询性能的重要手段。以下是一些关键的索引优化策略: 选择正确的索引列: 经常需要排序、分组和联…

建行商城网站单页面网站可以做自适应网站吗

流动性激励计划Moonbeam Ignite是帮助用户轻松愉快体验Moonbeam生态的趣味活动。在Moonbeam跨链连接的推动下,DeFi的各种可能性在这里爆发。DeFi或许不热门,但总有机会捡漏,了解Monbeam生态项目,我们邀请Moonbeam大使分享他们的研…

欢迎访问中国建设银行官方网站个人注册公司需要什么手续

2020深圳市公务员招录1069人公告已发布,报名时间:11月13日-19日16:00,报名入口:深圳市考试院专栏(http://hrss.sz.gov.cn/szksy/)或深圳市人事考试考生服务系统(以下简称考生服务系统,https://hrsstext.sz.gov.cn/ess/…

义乌个人兼职做建设网站查建筑公司网站

啥都不说先看效果图demoIMG_0270.PNG先来说说如何自定义大头针以及点击大头针时弹出的泡泡view一 : 自定义大头针新建CustomAnnotationView 继承自MAAnnotationView添加属性重写- (id)initWithAnnotation:(id)annotation reuseIdentifier:(NSString *)reuseIdentifier重写- (BO…

m2型虚拟主机带宽 网站网站建设的开题报告

原理 沙箱是一种安全机制,用于在受限制的环境中运行未信任的程序或代码。它的主要目的是防止这些程序或代码影响宿主系统或者访问非授权的数据。 在 Python 中,沙箱主要用于限制 Python 代码的能力,例如,阻止其访问文件系统、网…

关于网站设计的价格wordpress免费主题模板

qt-C笔记之主线程中使用异步逻辑来处理ROS事件循环和异步循环解决相互阻塞的问题 code review! 文章目录 qt-C笔记之主线程中使用异步逻辑来处理ROS事件循环和异步循环解决相互阻塞的问题1.Qt的app.exec()详解2.ros::spin()详解3.ros::AsyncSpinner详解4.主线程中结合使用的示…

企业网站模板论坛私密浏览器在线看

冒泡排序的两种策略&#xff1a; <script>// 第一种思路&#xff1a;// 一个数组中的数据&#xff0c;拿第一个和剩下的依次进行对比&#xff0c;数值小的赋值给第一个&#xff0c;一轮比较过后&#xff0c;则数值小的放在最前边。// 第二轮比较&#xff0c;则最前边的不…

网站内部链接优化方法asp源码下载

Ps&#xff1a;喂喂喂&#xff0c;你萌不要光收藏不点赞呀_(:з」∠)_emmmm... 搞清楚LSTM中的每个公式的每个细节为什么是这样子设计吗&#xff1f;想知道simple RNN是如何一步步的走向了LSTM吗&#xff1f;觉得LSTM的工作机制看不透&#xff1f;恭喜你打开了正确的文章&#…

重庆网站产品推广荣耀正品查询入口

使用 Offset Explorer&#xff08;也称为 Kafka Tool&#xff09;3.0.1 连接到 Kafka 并通过 SASL 进行身份验证&#xff0c;可以按照以下步骤进行配置&#xff1a; 1. 确保 Kafka 配置支持 SASL 首先&#xff0c;确保你的 Kafka 集群已配置为支持 SASL。你需要在 server.pro…

网站开发建设总结论坛发帖

目录  (1)优点&#xff1a; (2)缺点&#xff1a; (3)使用场景&#xff1a; (4)注意事项&#xff1a; (5)应用实例&#xff1a; 代码 备忘录模式(memento) 备忘录模式&#xff08;Memento Pattern&#xff09;保存一个对象的某个状态&#xff0c;以便在适当的时候恢复对…

电子商务网站建设第一章课后住房建设部官方网站

Compose版本发展 19年&#xff0c;Compose在Google IO大会横空出世&#xff0c;大家都议论纷纷&#xff0c;为其前途堪忧。 21年7月Compose 1.0的正式发布&#xff0c;却让大家看到了Google在推广Compose上的坚决&#xff0c;这也注定Compose会成为UI开发的新风向。 23年1月…

商城网站素材设置 iis 网站维护中

1 Makefile的作用 Makefile 指的是一个叫 Makefile 的文件,里面提前写了一些指令。每次要自动化的完成一个比较复杂项目的自动编译用的时候,就在命令行输入“make”命令Makefile使用。使用Makefile可以 “智能” 的知道: 1 哪些文件需要先进行编译。 2 当某一文件在某次mak…

软件园专业做网站网站建设提供资料表

给个关注&#xff1f;宝儿&#xff01; 给个关注&#xff1f;宝儿&#xff01; 给个关注&#xff1f;宝儿&#xff01; 1 JDBC基础 JDBC(Java Database Connectivity)是Java提供对数据库进行连接、操作的标准API。Java自身并不会去实现对数据库的连接、查询、更新等操作而是通…

网站导航一定要一样吗怎样打开网站

1.公安备案网址 https://beian.mps.gov.cn/ 选择用户登录->法人用户登录 左边的码下载APP&#xff0c;登上去之后用APP扫右边的码&#xff0c;人脸识别

怎么做网站表白合肥公司网站建设价格低

IP地址城市版查询接口 API是指能够根据IP地址查询其所在城市等地理位置信息的API接口。这类接口在网络安全、数据分析、广告投放等多个领域有广泛应用。以下是一些可用的IP地址城市版查询接口API及其简要介绍 1. 快证 IP归属地查询API 特点&#xff1a;支持IPv4 提供高精版、…

国外网站为啥速度慢垂直电商网站如何做内容运营

函数 需要声明原型支持不定参数 func sum(numbers ...int)int支持返回多值支持递归支持命名返回参数 // 命名返回参数 func add(a, b int) (sum int) {sum a breturn // 这里不需要显式地写出返回值&#xff0c;因为已经在函数签名中声明了命名返回参数 } 支持匿名函数、闭包…