当前位置: 首页 > news >正文

国外的网站建设商城网站互动性

国外的网站建设,商城网站互动性,建设申请网站首页,网页游戏网页游戏大全【数据结构】查找 数据结构中,有顺序查找、二分查找、散列查找、插值查找、斐波那契额查找 1.顺序查找 条件:待查找的元素与数组中的元素按顺序排列。算法:从数组的第一个元素开始,逐个比较,直到找到目标元素或遍历完…

【数据结构】查找

数据结构中,有顺序查找、二分查找、散列查找、插值查找、斐波那契额查找

1.顺序查找

  • 条件:待查找的元素与数组中的元素按顺序排列。
  • 算法:从数组的第一个元素开始,逐个比较,直到找到目标元素或遍历完整个数组。

java代码

  public static int sequentialSearch(int[] arr,int target){for(int i=0;i<arr.length;i++){if(arr[i]==target){return i;}}return -1;}

2.二分查找

  • 条件:待查找的元素与数组中的元素按顺序排列,且数组已经排好序,有序

  • 算法:在有序数组中,取中间位置的元素与目标元素进行比较,如果相等则返回中间位置的下标;如果目标元素比中间位置的元素小,则在左半部分继续查找;如果目标元素比中间位置的元素大,则在右半部分继续查找。重复以上步骤,直到找到目标元素或区间为空。

java代码

public static int binarySearch(int[] arr,int target){int left =0;int right=arr.length-1;while(left<=right){int mid = left+(right-left)/2;if(arr[mid]==target){return mid;} else if (target<arr[mid]) {right=mid-1;}else{left = mid+1;}}return -1;
}

3.散列查找

  • 条件:待查找的元素存储在一个哈希表中。

  • 算法:通过哈希函数将待查找的元素映射到一个桶中,然后遍历桶中的元素进行比较,直到找到目标元素或遍历完所有桶。

java代码

public static void hashSearch(Hashtable<Integer, String> table, int key) {int index = table.get(key);if (index != -1) {System.out.println("Found " + key + " at index " + index);} else {System.out.println("Not found " + key);}
}

4.插值查找

  • 条件:待查找的元素存储在一个已排序的数组中,但相邻元素之间的间隔不均匀

  • 算法:通过计算待查找元素在数组中的大概位置,然后在这个位置附近进行线性查找。

java代码

public static int interpolationSearch(int[] arr, int low, int high, int target) {while (low <= high && target >= arr[low] && target <= arr[high]) {int pos = low + ((target - arr[low]) * (high - low)) / (arr[high] - arr[low]);if (arr[pos] == target) {return pos;}if (arr[pos] < target) {low = pos + 1;} else {high = pos - 1;}}return -1;
}

5.斐波那契查找

条件:待查找的元素存储在一个有序序列中,每个元素都与前两个元素有关系。

算法:通过递归方式计算待查找元素的位置,直到找到目标元素或序列中没有更多元素。

java代码

public class FibonacciSearch {public static int fibonacciSearch(int[] arr, int key) {int low = 0;int high = arr.length - 1;int k = 0; // 斐波那契数列的下标int[] fib = FibonacciArr(arr.length);// 找到大于等于数组长度的最小斐波那契数列元素while (arr.length > fib[k] - 1) {k++;}// 将数组扩展到斐波那契数列元素的长度int[] temp = Arrays.copyOf(arr, fib[k] - 1);// 将扩展部分用数组最后一个元素填充for (int i = arr.length; i < temp.length; i++) {temp[i] = arr[arr.length - 1];}// 查找过程while (low <= high) {int mid = low + fib[k - 1] - 1;if (key < temp[mid]) {high = mid - 1;k -= 1;} else if (key > temp[mid]) {low = mid + 1;k -= 2;} else {return Math.min(mid, arr.length - 1);}}return -1;}// 生成斐波那契数列private static int[] FibonacciArr(int n) {int[] fib = new int[n];fib[0] = 1;fib[1] = 1;for (int i = 2; i < n; i++) {fib[i] = fib[i - 1] + fib[i - 2];}return fib;}
}
http://www.yayakq.cn/news/643276/

相关文章:

  • 昆山网站维护北京app网站建设
  • 微信公众号微网站怎么做的资阳网站设计
  • 网站开发技术考试题天津制作企业网站的
  • 用帝国做网站怎么样网站建设的认可
  • 请人开发网站多少钱wordpress的菜单功能
  • 网站建设七个步骤百度下载安装2021
  • 做博客的网站有哪些辽宁企业网站建设公司
  • 新沂做网站网站 模板 侵权
  • 深圳网站建设公司平台如何用凡科做自己的网站
  • jsp网站服务建设开题报告网站建设费 科目
  • 平面在线设计网站中国建筑工程承包网
  • 静态网站开发百科设计软件有几种
  • 十大免费ppt网站下载单机网页制作工具
  • 街舞舞团公司做网站公司在百度做网站
  • 企业网站用什么程序好wordpress获取所有文章列表
  • 建设银行信用卡账网站中关村在线官方网站电脑
  • 怎么做网站平台教程青岛有名的互联网公司
  • 网站首页设计多少钱域名 备案 没有网站吗
  • 做任务挣钱的网站软件开发自学需要
  • 高端网站建设 恩愉科技成都网站建设
  • 网站网页打开的速度什么决定的服务专业的网站建设公司
  • 网站备案字号wordpress修改文件上传路径
  • dw响应式网站模板下载网站空间到期 数据
  • 泉州最好的网站建设公司专业网站建设方案
  • 枣庄定制网站建设制作房天下怎样快速做网站
  • 网站正在建设中...为什么护卫神免费制作app生成器网站
  • 承德北京网站建设seo点击优化
  • 网站备案信息被工信部删除济宁建网站公司
  • 查看网站注册信息黑龙江网站建设工作室
  • 热可可怎么做视频网站有想做企业网站建设