




已阅读5页,还剩37页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
DYNAMICDATASTRUCTURES Adatastructureisaconstructusedtoorganizedatainaspecificway Sointhischapterwewill BecomefamiliarwithvectorsandhowtheyareusedinJava LearnwhatalinkeddatastructureisandhowitcanberealizedinJava FindouthowtomanipulatelinkedlistsLearnwhatiteratorsareandhowtocreateandusethem CHAPTER10 简介 集合将多个元素组成一个单元的对象用于存储 检索 操纵和传输数据集合框架提供用于管理对象集合的接口和类包括接口 实现和算法 体系结构 用于操纵集合的接口 Collection接口 集合框架的根通用方法booleancontains Objecta booleanequals Objecta Iteratoriterator intsize voidclear booleanadd Objecta Set接口 扩展Collection接口不允许重复元素对add equals 和hashcode 方法添加了限制HashSet和TreeSet是Set的实现 SortedSet接口 扩展了Set接口元素按升序排序重要异常ClassCastExceptionNullPointerException List接口2 1 具有顺序的集合扩展了Collection接口元素可以通过其整型下标访问可以包含重复元素 List接口2 2 方法分类定位方法get set add remove addAll 搜索方法indexOf 和lastIndexOf ListIterator方法listIterator 和subList Map接口 将键映射至值的对象每个键最多都只能映射至一个值重要方法基本操作put get remove containsKey containsValue size 和isEmpty 批操作putAll 和clear 集合视图keySet values 和entrySet 实现2 1 用于存储集合的实际数据对象重要集合类AbstractCollection类提供Collection接口的框架实现AbstractList类提供List接口的框架实现AbstractSequentialList类是List接口的实现LinkedList类提供多个方法 用于在列表开始处和结尾处获得 删除和插入元素 简介 集合将多个元素组成一个单元的对象用于存储 检索 操纵和传输数据集合框架提供用于管理对象集合的接口和类包括接口 实现和算法 体系结构 用于操纵集合的接口 Collection接口 集合框架的根通用方法booleancontains Objecta booleanequals Objecta Iteratoriterator intsize voidclear booleanadd Objecta Set接口 扩展Collection接口不允许重复元素对add equals 和hashcode 方法添加了限制HashSet和TreeSet是Set的实现 SortedSet接口 扩展了Set接口元素按升序排序重要异常ClassCastExceptionNullPointerException List接口2 1 具有顺序的集合扩展了Collection接口元素可以通过其整型下标访问可以包含重复元素 List接口2 2 方法分类定位方法get set add remove addAll 搜索方法indexOf 和lastIndexOf ListIterator方法listIterator 和subList Map接口 将键映射至值的对象每个键最多都只能映射至一个值重要方法基本操作put get remove containsKey containsValue size 和isEmpty 批操作putAll 和clear 集合视图keySet values 和entrySet 实现2 1 用于存储集合的实际数据对象重要集合类AbstractCollection类提供Collection接口的框架实现AbstractList类提供List接口的框架实现AbstractSequentialList类是List接口的实现LinkedList类提供多个方法 用于在列表开始处和结尾处获得 删除和插入元素 实现2 2 重要集合类 续 ArrayList类是List接口的可变大小数组实现AbstractSet类提供Set接口的框架实现HashSet类为基本操作提供固定时间性能TreeSet类确保排序集将按元素升序 example importjava util publicclassListOper publicstaticvoidmain String args if args length 0 System out println 你必须提供列表元素 作为命令行参数 请重试 System exit 0 System out println Listl newArrayList for inti 0 i args length i l add args i Collections reverse l System out println 逆序的列表如下 System out println l Collections sort l System out println 排序的列表如下 System out println l intindex Collections binarySearch l c System out println 元素 c 的位置为 index Collections fill l 一 System out println 用字 一 填充后的列表如下 System out println l Listll newArrayList ll add 第一 ll add 第二 ll add 第三 Collections copy l ll System out println 用ll的元素替代后的列表如下 System out println l 算法3 1 Collections类中的静态方法用于排序 搜索 混排和数据操纵方法的第一个参数是要执行操作的集合重要异常ClassCastExceptionUnsupportedOperationException 算法3 2 算法3 3 classAlgorithmExample publicstaticvoidmain Stringargs LinkedListlink newLinkedList link add newInteger 10 link add newInteger 35 link add newInteger 23 link add newInteger 54 link add newInteger 36 Comparatorcmp Collections reverseOrder Collections sort link cmp Iteratorit link iterator System out println 逆序排序的列表为 while it hasNext System out println it next System out println 给定列表中的最大值为 Collections max link System out println 给定列表中的最小值为 Collections min link 多简单 集合框架的优点 提供一组可用的集合接口提供有效的数据结构和算法可以方便地扩展或改写集合接口的实现都是可交换的使设计新API的工作降到最少接口和算法的可重用性 Vector类 实现可变长度的对象数组组件可以使用整型下标访问构造函数Vector Vector Collectionc Vector intcap Vector intcap intinc Enumeration接口 此接口定义了多个方法 有助于枚举对象集合中的元素 BooleanhasMoreElements ObjectnextElement Enumeratione v elements While e hasMoreElements System out println e nextElement Methodinvector PublicvoidsetElementAt objectnewElement intindex PublicobjectelementAt intindex PublicvoidaddElement objectnewElement PublicvoidinsertElementAt objectnewElement intindex PublicvoidremoveElementAt intindex PublicbooleanremoveElement ObjecttheElement PublicvoidremoveAllElements Publicbooleancontains Objecttarget PublicintindexOf Objecttarget PublicintindexOf Objecttarget intstartIndex PublicintlastIndexOf Objecttarget PublicObjectfirstElement PublicObjectlastElement PublicboolearnisEmpty Publicintsize Publicintcapacity PublicvoidensureCapacity intnewCapacity PublicvoidtrimToSize PublicvoidsetSize intnewSize PublicObjectclone LinkedList Alinkedlistisadatastructureconsistingofobjectsknownasnodes suchthateachnodecancontainbothdataandareferencetooneothernodesothattheentirelinkedlistformsalist asillustratedinDisplay10 3 Thefirstnodeinthelistisknownastheheadnode Inlinkedlistmostnodeshavenoname Thevariableheadcontainsareferencetothefirstnodeinalinkedlist So headcanbeusedasanameforthefirstnode However theothernodesinthelinkedlisthavenonamedvariablethatcontainsareferencetoanyofthem andsotherestofthenodesinthelinkedlistareusuallynameless Theonlywaytonameoneofthemisviasomeindirectreference likehead link link orbyusinganothervariableoftypeListNode suchasthelocalvariablepositioninthemethodshowList Display10 5 page683 UsenullfortheEmptyListLet ssaythevariableheadissupposedtocontainareferencetothefirstnodeinalinkedlist Linkedlistsusuallystartoutempty Whatvaluedogiveheaduntilthefirstnodeisadded Giveheadthevaluenulltoindicateemptylist Thisistraditionalanditworksoutnicelyformanylinkedlistmanipulationalgorithms NodeInnerClassYoucanmakealinkedlist orotherlinkeddatastructure self containedbymakingthenodeclassaninnerclassofthelinkedlistclass Somethingelse Stack类 表示后进先出的对象堆栈一个构造函数 创建空堆栈Stack Booleanempty Objectpeek Objectpop Objectpush Objecta Intsearch Objecta importjava util classStackEg publicstaticvoidmain String args Stacks newStack s push 一 s push 二 s push 三 s push 四 System out println 存储在堆栈中的元素为 System out println s System out println while s empty System out println s pop Hashtable类 以键值对的形式存储数据键被散列 散列码用作存储值的下标构造函数Hashtable Hashtable intcap Hashtable intcap floatload Hashtable Mapm importjava util classHashTableExample publicstaticvoidmain Stringargs Hashtableh newHashtable Enumeratione Stringstr doublebal h put Maria newDouble 4545 50 h put Joseph newDouble 2000 00 h put Johnson newDouble 5000 00 e h keys while e hasMoreElements str String e nextElement System out println str h get str System out println bal Double h get Maria doubleValue h put Maria newDouble bal 1000 System out println Maria snewbalance h get Maria Iterators Supposeyouhaveacollectionofdataitems suchasanarrayoralinkedlist Anyobjectthatallowsyoutostepthroughthecollectiononeitematatimeinareasonablewayiscalledaniterator By areasonableway wemeanthateachitemisvisitedexactlyonceinonefullcycleofiterations andeachitemcanhaveitsdatareadand ifthedataitemsallowit canhavethedatachanged Forexample anintvariablethatholdsanindexvaluecanserveasaniteratorforanarray Togotothenextiteminthecollection yourcodeneedonlyincreasethevalueoftheintvariablebyone ThejavaIteratorinterface JavahasaninterfacenamedIteratorthatspecifieshowJavawouldlikeaniteratortobehave Itisinthepackagejava util Ouriteratorsdonotsatisfythisinterface butitiseasytodefineclassesthatuseouriteratorsandthatdosatisfythisinterface Theiteratorinterfaceusesexceptionhandling butisnotdifficulttounderstand InSelf TestQuestion19youareaskedtodefinealinkedlistclasstatsatisfiestheiteratorinterface CHAPTER11 Ifamethoddefinitioncontainsaninvocationoftheverymethodbeingdefined thenthatinvocationiscalledarecursivecallorrecursiveinvocation Example publicvoidhanno charA charB charC n if n 1 move A B A Belse hanno A C B n 1 move A B hanno C B A n1 RECURSION SuccessfulRecursion Adefineofamethodthatincludesarecursiveinvocationofthemethodbeingdefinedwillnotbehavecorrectlyunlessyoufollowsomespecificdesignguidelines Thefollwingrulesapplytomostcasesthatinvolverecursion Theheartofthemethoddefinitioncanbeanif else statementorsomeotherbranchingstatementthatleadstodifferentcases dependingonsomepropertyofaparametertothemethodbeingdefiend SuccessfulRecursion2 Oneormoreofthebrancesincludearecursiveinvocationofthemethod Theserecursiveinvocationsshouldinsomesenseuse smaller argumentsorsolve smaller versionsofthetaskperformedbythemethod Oneormorebranchesshouldincludenorecursiveinvocations Thesearethestoppingcases alseknownasthebasecases StackOverflow Whenamethodinvocationleadstoinfiniterecursion yourprogramislikelytoendwithanerrormessagethatreferstoa stackoverflow Thetermstackreferstoadatastructurethatisusedtokeeptrackofrecursivecalls andotherthingsaswell Intuitivelyarecordofeachrecursivecallisstoredonsomethinganalogoustoapieceofpaper Thesepiecesofpaperareintuitivelystackedoneontopoftheother Whenthis stack becomestoolargeforthecomputertohandle thatiscalledastackoverflow Summary Vectorscanbethoughtofasarraysthatcangrowinlength ThebasetypeofallvectorsisObject Thus theelementsofavectormaybeofanyclasstype buttheycannotbeofaprimitivetype Alinkedlistisadatastructureconsistingofobjectsknownasnodes suchthateachnodecancontaindataandsuchthateachnodehasareferencetooneothernodesothattheentirelinkedlistformsalist Summary Youcanmakealinkedlistself containedbymakingthenodeclassaninnerclassofthelinkedclass Youcanuseaniterato
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年河北邯郸市口腔医院秋季博硕人才引进12人备考考试题库附答案解析
- 2025贵州省康复医院合同制人员招聘备考考试题库附答案解析
- 2025甘肃天水市事业单位招聘工作人员270人备考练习题库及答案解析
- 2025贵州江口县第六幼儿园招聘备考考试题库附答案解析
- 2025马关县小坝子镇公开储备一批村“两委”后备干部(16人)笔试备考题库及答案解析
- 2025福建漳州市芗江人力资源服务有限公司招聘若干人备考考试题库附答案解析
- 2025年金华市中医医院招聘编外工作人员5人(第二批)备考考试题库附答案解析
- 工厂安全培训标准周期课件
- 2025江西宜春市直事业单位选调22人备考考试题库附答案解析
- 掌握互动教学法
- 认识大脑课件
- 急性胃十二指肠穿孔课件
- 多传感器融合赋能无人驾驶列车的安全感知-洞察及研究
- 2025时事政治必考试题库及答案及完整答案详解
- 药事管理知识与技能培训课件
- 2025人教版(2024)一年级上册数学教学计划 (三篇)
- 汉字的六种结构方式
- 手术部(室)医院感染控制标准WST855-2025解读课件
- 酒店法律培训课件
- 公证一般程序课件
- 2025年食品安全员考试题库(含答案)
评论
0/150
提交评论