付费下载
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1public sicuseLoop(String arr, StringValue) 2for(String s: arr) if(s.equals(Value)3return true;4return false;56 )使用一个简单循环:1public sicuseSet(String arr, StringValue) 2Set set = new HashSet(Arrays.asList(arr); return set.contains(Value);34 )使用 9KZ:public sicuseList(String arr, StringValue) return Arra
2、ys.asList(arr).contains(Value);3如何检查一个未排序的数组中是否包含某个特定值,这是一个在 0GG 中非常实用并且频繁使用的操作。另外,这也是 9ZGIQ 5KXLRU 上面非常受关注。在得票数最多的中,可以看到,检查数组中是否包含特定值可以用多种不同的方式实现,但是时间复杂度差别很大。下面,我将为大家展示各种方法及其需要花费的时间。 检查数组中是否包含特定值的四种不同方法 )使用 2OYZ:如何高效地判断数组中是否包含某特定值1public sic void main(String args) String arr = new String CD, BC, EF
3、, DE, AB;23/use listlong startTime = System.nanoTime();4for (i = 0; i 100000; i+) useList(arr, A);long endTime = System.nanoTime();long duration = endTime - startTime;System.out.prln(useList: + duration / 1000000);89/use setstartTime = System.nanoTime();10for (i = 0; i 0)return true;elsereturn false
4、;67 )使用 XXG_Y HOTGX_9KGXIN :注:下面的代码是错误的,这样写出来仅仅为了理解方便。HOTGX_9KGXIN 只能用于已排好序的数组中。所以,你会发现下面结果很奇怪。7结果:12endTime = System.nanoTime();13duration = endTime - startTime;System.out.prln(useSet: + duration / 1000000);14/use loopstartTime = System.nanoTime();for (i = 0; i 100000; i+) useLoop(arr, A);18endTime
5、 = System.nanoTime();duration = endTime - startTime;System.out.prln(useLoop: + duration / 1000000);/use Arrays.binarySearch()startTime = System.nanoTime();for (i = 0; i 100000; i+) useArraysBinarySearch(arr, A);24endTime = System.nanoTime();duration = endTime - startTime;System.out.prln(useArrayBina
6、ry: + duration / 1000000);27282930313233343536373839结果:1String arr = new String10000;23Random s = new Random(); for(i=0; i 10000; i+)4arri = String.valueOext();56对于长度为 1 的数组:1useList: 1122useSet: 2055 useLoop: 993useArrayBinary: 124结果:1String arr = new String1000;23Random s = new Random(); for(i=0;
7、i 1000; i+)4arri = String.valueOext();56对于长度为 1 的数组:1useList: 132useSet: 72 useLoop: 53useArraysBinarySearch: 94很明显,使用简单循环的方法比使用其他任何集合效率更高。许多开发者会使用第法,但是它并不是高效的。将数组压入 )URRKIZOUT 类型中,需要首先将数组元素遍历一遍,然后再使用集合类做其他操作。如果使用 XXG_Y HOTGX_9KGXIN 方法,数组必须是已排序的。由于上面的数组并没有进行排序,所以该方法不可使用。实际上,如果你需要借助数组或者集合类高效地检查数组中是否包含特
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 展馆物料制作方案范本
- 2026年企业人力资源管理师之三级人力资源管理师通关测试卷及完整答案详解(全优)
- 2026年土木工程师《岩土专业知识》押题宝典通关考试题库(巩固)附答案详解
- 2026年建筑工人考证考试题库含答案详解【黄金题型】
- 2026年一级造价师之建设工程造价管理通关测试卷AB卷附答案详解
- 2026年70周岁以上需要补换领驾照三力考前冲刺练习题附完整答案详解【名师系列】
- 2026年智慧树答案药事管理学智慧树网课章节综合提升练习试题附参考答案详解(模拟题)
- 2026年大学GIS应用开发期末模拟题库【B卷】附答案详解
- 2026年档案岗位从业资格考试及答案解析
- (2025年)新危险源辨识培训考试试卷含答案
- 2026深圳中考历史考前冲刺卷含答案
- 2026哈尔滨兰兴资产运营管理有限公司公开招聘备考题库(含答案详解)
- 卫生院信用管理工作制度
- 2026年新疆投资发展集团有限责任公司校园招聘笔试备考试题及答案解析
- 2026四川省现代种业发展集团成都农业开发有限公司社会化招聘拟人员笔试历年典型考点题库附带答案详解
- 物流公司运输调度工作流程
- 血液内科三基三严考试题库及答案
- 【《中国智能手机出口现状分析概述》3000字】
- DB43-T 3447-2025 烟花爆竹生产企业对标改造技术指南
- 电力系统概述课件
- 道路桥梁建设进展调研报告
评论
0/150
提交评论