做外贸营销型网站浅谈博物馆网站建设意义

news/2025/10/4 18:31:30/文章来源:
做外贸营销型网站,浅谈博物馆网站建设意义,好看的网站模板,wordpress取回密码收不到邮件目录 基本查找*#xff1a; 二分查找*#xff1a; 数据单调递增#xff1a; 数据单调递减#xff1a; 总结规律#xff1a; 插值查找*#xff1a; 斐波那契查找#xff08;了解原理#xff09;#xff1a;以后补 分块 查找*#xff1a; 特殊 情况#xff0…目录 基本查找* 二分查找* 数据单调递增 数据单调递减 总结规律 插值查找* 斐波那契查找了解原理以后补 分块 查找* 特殊 情况无规律的数据 以上小结 哈希查找了解原理以后补 树表查找涉及数据结构以后补 基本查找* 也叫线性查找 从头到尾依次遍历 示例 需求 1定义一个方法利用基本查找查询某个元素在数组中是否存在 public static void main(String[] args) { int[] arr {1, 2, 3, 4, 5, 6}; System.out.println(search(arr, 4)); } //方法 public static boolean search(int[] arr, int number) {for (int i 0; i arr.length; i) {if (arr[i] number) {return true;}}return false; } 需求 2定义一个方法利用基本查找查询某个元素在数组中的索引 要求不需要考虑数组中元素是否重复 public static void main(String[] args) {int[]arr{1,2,3,4,5,6,6,8,6};System.out.println(index(arr, 6));//5}public static int index(int[] arr, int number) {for (int i 0; i arr.length; i) {if (arr[i] number) {return i;}}return -1; } 控制台 5 需求 3 要求在上一题的基础上 需要考虑数组中元素有重复的可能性 思路也就是若有重复的数据要返回多个索引 我们可以用一个集合来存放索引因为集合有 add 方法添加方便,最后遍历集合即可。 示例; public static void main(String[] args) {int []arr{1,2,2,2,3,2};ArrayList index index(arr, 2);for (int i 0; i index.size(); i) {System.out.println(index.get(i));}}public static ArrayList index(int []arr, int number){//核心定义集合存放索引ArrayListIntegerlistnew ArrayList();for (int i 0; i arr.length; i) {if (arr[i]number){list.add(i);}}return list;} 二分查找* 也叫折半查找 前提条件 元素必须是有序的从小到大或是从大到小 核心逻辑 每次排除一半的查找范围。 注意点: 如果是无序的也可以先进行排序。但是排序后会改变原有数据的顺序也就是说元素对应的索引变了这时再获取索引无意义这是只能适用于查找数据是否存在再容器中。 数据单调递增 如 可以知道最小索引时 0 最大索引是 7 中间索引是07/23 第一次查找中间索引对应的值是 25 又因为是递增数组 所以说 38 一定在中间索引对应的值的右边。 这时我们可以让 minmid1max 不用变目的是缩小查找范围 则下一次查找的区域索引 就 是 4~7。 代码语言可以这样写 if(arr[mid]number){ minmid1; } 同理, 若我们要查找 21 第一次查找 中间索引对应的值是 25 又因为是递增数组 所以说 21 一定在中间索引对应的值的左边。 这时我们可以让 maxmid-1min 不用变目的是缩小查找范围 则下一次查找的区域索引是 0-2 代码语言 if(numberarr[mid]){ maxmid-1; } 之后的每一次查找 mid 索引值都会因为 min 或 max 的变化而变化使得范围不断缩小。 数据单调递减 以上是数据单调递增的情况 单调递减的情况则相反 第一次查找 中间索引对应的值是 6 又因为是递减数组 所以说 3 一定在中间索引对应的值的右边。 这时我们可以让 minmid1max 不用变目的是缩小查找范围 则下一次查找的区域索引是 5-8 代码语言 if(numberarr[mid]){ minmid1 } 第一次查找 中间索引对应的值是 6 又因为是递减数组 所以说 7 一定在中间索引对应的值的 左 边。 这时我们可以让 maxmid-1min 不用变目的是缩小查找范围 则下一次查找的区域索引是 0-3 代码语言 if(numberarr[mid]){ maxmid-1; } 之后的每一次查找 mid 索引值都会因为 min 或 max 的变化而变化使得范围不断缩小。 总结规律 要根据数组的单调性判断 number 和 arr [mid] 的位置关系。 当要查找的数据在中间索引对应的数据右边时位置关系无关大小min mid1max 不变。 当要查找的数据在中间索引对应的数据左边时位置关系无关大小min 不变max mid-1。 例题 代码除了要写上面讨论的中间索引对应值和目标值的关系 还要考虑中间索引恰好是要查的数的情况、查找数在数组中不存在的情况具体如下 public static void main(String[] args) {//前提有序//需求定义一个方法利用二分查找查询某个元素在数组中的索引int[] arr {7, 23, 79, 81, 103, 127, 131, 147};System.out.println(index(arr, 150)); }public static int index(int[] arr, int number) {//定义两个范围记录查找范围int min 0;int max arr.length - 1;//不知道要循环多少次while(true){//先找中间位置--注意放在循环内会不断变化int mid (min max) / 2;//如果中间索引恰好是要查的数直接返回索引if (arr[mid] number) {return mid;}else if (arr[mid] number) {//要查的数在中间位置的右边max不变min mid 1;}else if ( numberarr[mid] ) {//要查的数在中间位置的左边min不变max mid - 1;}//当出现这种情况了就表示查找的数在数组中不存在if (minmax){return -1;}}} 插值查找* 基于二分法使 mid 更加靠近要查找的数字。 差值查找前提也是数据有序。 low,high 分别代表最低最高索引 如 细节对于表长较大而关键字分布又比较均匀的查找表来说插值查找算法的平均性能比折半查找要好的多。反之数组中如果分布非常不均匀那么插值查找未必是很合适的选择。 public static void main(String[] args) {//前提有序//需求定义一个方法利用插值查找查询某个元素在数组中的索引int[] arr {7, 23, 79, 81, 103, 127, 131, 147};System.out.println(index(arr, 23)); }public static int index(int[] arr, int number) {//定义两个范围记录查找范围int min 0;int max arr.length - 1;//不知道要循环多少次while(true){//先找中间位置--注意放在循环内会不断变化int mid min(number-arr[min])/(arr[max]-arr[min])*(max-min);//如果中间索引恰好是要查的数直接返回索引if (arr[mid] number) {return mid;}else if (arr[mid] number) {//要查的数在中间位置的右边max不变min mid 1;}else if ( numberarr[mid] ) {//要查的数在中间位置的左边min不变max mid - 1;}//当出现这种情况了就表示查找的数在数组中不存在if (minmax){return -1;}}} 代码和二分几乎一样只要修改一下mid的计算方式即可 斐波那契查找了解原理以后补 根据黄金分割点来计算mid指向的位置 分块 查找* 使用前提: 数据 块内无序块间有序。 我们一般 分的块数为 数据个数开根号。 分的块必须保证后一块的所有数都必须比前一块的最大值大。 分块查找的核心思想 先确定目标数在哪一块当中然后获取当前块的索引会提前将每一块放入索引表中然后在该块中遍历查找即可。 语言描述思路: 我们分完块后可以创建一个 Bolck 类描述不同的块 内含属性块内最大值、开始索引、结束索引 2.然后在测试类中创建不同块对象即可并根据 数组数据 初始化对象属性即可 3.之后把对象存入 Block 类型的数组 4.假设查找数字 5.先定义一个方法看看这个数在哪一块中 //注意if的判断条件和我们之前分块 规则 的关系 6.获取到数据所在块的索引后我们就要开始用到另外两个属性 了 为方便演示另外再定义一个方法 结束。 特殊 情况无规律的数据 当不满足块内无序块间有序完全找不到规律时 分块思想各块间不能有交集。 示例: package com.lt.search;public class BlockSearch2 {public static void main(String[] args) {//当不满足块内无序块间有序完全找不到规律时//分块思想不能有交集int[] arr {27,22,30,40,36,13,19,16,20,7,10,43,50,48};Block b1new Block(22,40,0,4);Block b2new Block(13,20,5,8);Block b3new Block(7,10,9,10);Block b4new Block(43,50,11,13);Block []blocksArr{b1,b2,b3,b4};int number48;int Index getIndex(arr,blocksArr,number);System.out.println(Index);}//获取索引public static int getIndex(int[]arr,Block[] blocksArr,int number) {int blockIndex getBlock(blocksArr, number);if (blockIndex-1){return -1;//表示数字不在数组中}int startIndex blocksArr[blockIndex].getStartIndex();int endIndex blocksArr[blockIndex].getEndIndex();//注意等号for (int i startIndex; i endIndex ; i) {if(numberarr[i]){return i;}}return -1;//表示要查找的数在块中找没有}//先获取number在哪个块中public static int getBlock(Block[]blocksArr,int number){for (int i 0; i blocksArr.length ; i) {//分块思想决定了这里if的判断条件if (numberblocksArr[i].getMax()numberblocksArr[i].getMin()){return i;//返回块的索引}}return -1;//表示要查找的数不在任何块中}}class Block{private int min;private int max;private int startIndex;private int endIndex;//构造setget } 以上小结 基本查找 数据没有任何顺序 二分查找、插值查找、斐波那契查找 数据一定要有顺序 二分查找插值查找斐波那契额查询各自的特点相同点 都是通过不断的缩小范围来查找对应的数据不同点 计算mid的方式不一样二分查找mid每次都是指向范围的中间位置插值查找mid尽可能的靠近要查找的数据但是要求数据尽可能的分布均匀斐波那契额查找根据黄金分割点来计算mid指向的位置 哈希查找了解原理以后补 树表查找涉及数据结构以后补

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

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

相关文章

深圳哪家做网站最好辽宁建设工程信息网ca锁激活

本文目录 本系列文章从新开始为啥要用TypeScript官方文档程序框架从package.json开始tsconfig.jsonJest的配置 jest.config.js服务的实现自动化测试setup.ts文件夹integration 执行及测试对应代码及branch 本系列文章 SAP CAP篇一: 快速创建一个Service,基于Java的…

阿里云万网域名关键词优化排名软件

1. Json 数据解析和绑定 客户端传参,后端接收并解析到结构体 package mainimport ("github.com/gin-gonic/gin""net/http" )// 定义接收数据的结构体 type Login struct {// binding:"required"修饰的字段,若接收为空值…

NFC 贴卡自动拨打微信视频电话

思路来源:b站的视频教程: https://www.bilibili.com/video/BV1Vo3izgEDT/ 文字教程: 下面的操作均在需要贴卡自动拨打微信电话的手机进行:1)下载 NFC Tasks 、NFC Tools、自动脚本精灵,权限打开通知、辅助功能、…

请人建网站wordpress 不做SEO

在项目正式上线之前,我们通常需要通过压测来评估当前系统能够支撑的请求量、排查可能存在的隐藏bug;压力测试(压测)是确保系统在高负载情况下仍能稳定运行的重要步骤。通过模拟高并发场景,可以评估系统的性能瓶颈、可靠…

实用指南:d-分离:图模型中的条件独立性判定准则

实用指南:d-分离:图模型中的条件独立性判定准则pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas",…

微信嵌入手机网站浙江建设继续教育网站首页

题目背景 思路解析:很经典的贪心问题,把物品按照从便宜到贵的顺序排好序,然后按照富贵程度排人,直接暴力会tle所以这里采用双指针. #include<iostream> #include<algorithm> #include<cstring> #include<cmath> #include<string> using namesp…

win7可以做网站吗宠物网站模板下载

几年的时间&#xff0c;从OneNote到为知笔记&#xff0c;再到印象笔记&#xff0c;再回到为知笔记和OneNote&#xff0c;用下来感觉各有优势&#xff0c;也有不爽的地方。 早年间OneNote的同步很有问题&#xff0c;一次同步冲突导致失去了几乎所有笔记本。心灰意冷之下就离开了…

[MCP] 监听资源更新

有两种形式:资源列表变化 资源内容变化资源列表变化 用于监听资源目录是否发生增删改。 工作机制 当服务器上的资源列表发生变化时(例如 resources/list 中的项发生增删),服务器主动发送通知: notifications/reso…

详细介绍:Sentinel 深度解析:限流与熔断降级的微服务稳定性保障实践

详细介绍:Sentinel 深度解析:限流与熔断降级的微服务稳定性保障实践2025-10-04 18:15 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto…

GitHub 使用技巧 - 指南

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

[RAG] 基础知识

RAG基础知识 基本介绍 RAG,全称 Retrieval-Augmented Generation,中文:检索增强生成 核心思想:为大模型补充来自于外部的相关数据与上下文,从而帮助大模型生成更丰富、更准确、更可靠的内容。 也就是 临时给大模型…

CF1408F Two Different

关键是要想到可以“借数”CF1408F Two Different 挺好的一道思维题。 手玩几个例子之后发现以下性质: 1、直接变的话,只能同时把 \(2^k\) 个数变成一样的,次数大概是 \(2^{k - 1} \times k\)。 2、零散的小堆可以向…

青岛住房和城乡建设部网站网站登录不了

在Cocos Creator中&#xff0c;脚本代码文件分为模块和插件两种方式&#xff1a; 模块一般就是项目的脚本&#xff0c;包含项目中创建的代码、引擎模块、第三方模块。 插件脚本&#xff0c;是指从 Cocos Creator 属性检查器中导入的插件&#xff0c;一般是引入第三方引入库文件…

区块链网站用vue.js做怎么样早8晚5双休的工作

TimeStamp 更新操作可能伴随数据冲突&#xff0c;我们可以通过并发处理妥善解决这一方面的问题。避免数据冲突比较方便的做法是自动加入字节数组&#xff08;byte[]&#xff09;类型的TimeStamp属性&#xff0c;对应到数据表中的rowvewsion类型字段&#xff0c;自动监控数据的…

数据结构 - 字典树 Trie

字典树(Trie)是一种树形数据结构,主要用于高效地存储和检索字符串集合。它通过利用字符串的公共前缀来节省存储空间,常用于词典查询、自动补全等场景。 1. 什么是字典树 字典树的每条边代表一个字符,从根节点到某…

激活函数实现

激活函数实现 1.1:创建激活函数工程目录 创建激活函数目录- src (存放源代码)- testbench (存放测试文件)- docs (存放文档)- lut_data (存放查找表数据)- python_utils (存放Python辅助脚本…

漏洞赏金入门指南:从零开始的实战方法论

本文详细介绍了漏洞赏金猎人的入门方法论,包括基础知识学习、时间分配策略、持续学习的重要性,以及如何保持动力和专注度。文章打破了"快速致富"的迷思,为初学者提供了切实可行的成长路径。漏洞赏金入门指…

网站建设数据库搭建电影爱好网

在使用svn的过程中&#xff0c;可能出现整个svn崩溃&#xff0c; 例如cleanup 失败的情况&#xff0c;类似于 这时可以下载本贴资源文件并解压。 或者直接访问网站 SQLite Download Page 进行下载 解压后得到 sqlite3.exe 放到发生问题的svn根目录的.svn路径下 右键呼出pow…

PMON failed to acquire latch 的报错及sqlplus / as sysdba 无法连接 - 详解

PMON failed to acquire latch 的报错及sqlplus / as sysdba 无法连接 - 详解pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-fam…

【C++哲学】面向对象的三大特性之 多态 - 实践

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …