




下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Vue使用动画实现冒泡排序、选择排序废话不多说,先看一下使用Vue来实现冒泡排序的动画效果(注意:此处调整了交换过度时间为50毫秒)BubbleSortVisualizer再来看一下选择排序的动画效果(注意:同样加快了动画过渡时间)原理:由于Vue是基于MVVM的,所以我们只需要绑定属性后,直接更改绑定的数据即可,不需要每次操纵Dom树了。下面为的图片中的方法就是提取出来的公共方法,动画效果是使用的CSS特性。/激活/用参数payload的indexes属性中所有成员,与state.cards的每个成员(card)的sortindex属性与进行匹配,/如果找到相等的,就将state.cards
2、的成员(card)的isActive设置为trueactivate(state,payload)payload.indexes.forEach(index)=state.cards.forEach(card)=if(card.sortIndex=index)card.isActive=true;););,/释放/用参数payload的indexes属性中所有成员,与state.cards的每个成员(card)的sortIndex属性与进行匹配,/如果找到相等的,就将state.cards的成员(card)的isActive设置为falsedeactivate(state,payload)pay
3、load.indexes.forEach(index)=state.cards.forEach(card)=if(card.sortIndex=index)card.isActive=false;););,/锁定/用参数payload的indexes属性中所有成员,与state.cards的每个成员(card)的sortIndex属性与进行匹配,/如果找到相等的,就将state.cards的成员(card)的isLocked设置为truelock(state,payload)payload.indexes.forEach(index)=state.cards.forEach(card)=if(
4、card.sortIndex=index)card.isLocked=true;););,/解锁/用参数payload的indexes属性中所有成员,与state.cards的每个成员(card)的sortIndex属性与进行匹配,/如果找到相等的,就将state.cards的成员(card)的isLocked设置为falseunlock(state,payload)payload.indexes.forEach(index)=state.cards.forEach(card)=if(card.sortIndex=index)card.isLocked=false;););下面一步就是写算法的
5、实现过程了,冒泡算法和选择排序算法代码如下。冒泡算法实现步骤:/冒泡排序方法,返回包括每一步的数组bubbleSort(values)/sequence为包括每一步内容的数组letsequence=;/swapped为判断是否已经排序好的标志位letswapped;/indexLastUnsorted用来减少不必要的循环letindexLastUnsorted=values.length-1;doswapped=false;for(leti=0;ivaluesi+1)lettemp=valuesi;valuesi=valuesi+1;valuesi+1=temp;swapped=true;/满
6、足交换的条件,就重新定义所有card的sortIndex属性sequence.push(type:swap,indexes:i,i+1);/结束这次循环之前,把原来两个card的isActive的值为true的,设置为falsesequence.push(type:deactivate,indexes:i,i+1);/外层循环,每循环完一次,就锁定最后一个card,下次这个card就不参与循环sequence.push(type:lock,indexes:indexLastUnsorted);indexLastUnsorted-;while(swapped);/如果提前排序好了,把剩下的car
7、d全部锁定letskipped=Array.from(Array(indexLastUnsorted+1).keys();sequence.push(type:lock,indexes:skipped);/修改done为true,完成排序sequence.push(type:done);console.log(包括每一步内容的数组sequence);returnsequence;选择排序算法实现步骤:/选择排序方法,返回包括每一步的数组(从小至大的顺序)selectionSort(values)/sequence为包括每一步内容的数组letsequence=;/数组的长度letlen=valu
8、es.1ength;letminIndex;for(leti=0;ilen-1;i+)minIndex=i;将第minIndex个元素设为锁定sequence.push(type:lock,indexes:minIndex);for(letj=i+1;jlen;j+)sequence.push(type:activate,indexes:j);if(valuesjvaluesminIndex)sequence.push(type:unlock,indexes:minIndex);sequence.push(type:deactivate,indexes:minIndex);sequence.push(type:lock,indexes:j);将比i元素小的的索引保存minIndex=j;elsesequence.push(type:deactivate,indexes:j);if(minIndex!=i)lettemp=valuesi;valuesi=val
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 建筑物产权抵押合同
- 人教版历史与社会九年级上册第二单元第一课《第一个社会主义国家的建立和发展 》教学设计
- 公证合同范本
- TCATIS 028-2024 零信任能力成熟度模型
- 初中生物课堂合作学习模式的实践与革新:基于实证的深度剖析
- 第10课 美图浏览-滚动条和列表框 教学设计-2023--2024学年清华大学版(2012)初中信息技术九年级上册
- 七年级生物上册第二单元生物体的结构层次第二章细胞怎样构成生物体第四节单细胞生物习题4新版新人教版
- 七年级生物上册第一单元生物和生物圈第一章认识生物第二节调查周边环境中的生物习题3新版新人教版
- Unit 5 Topic 2 Section B 教学设计 -2024-2025学年仁爱科普版英语八年级下册001
- Unit6 There are four seasons in a year(教学设计)-2024-2025学年人教精通版英语六年级上册
- 钻机的基础知识介绍
- ICU重症患者康复护理
- 简单词考研英语5500单词表
- 金茂入职前的在线测评题
- 广东省佛山市2024年中考英语模拟试卷(含答案)
- ISO14644国际标准(中文版)
- DB22T 1189.2-2011 无公害农产品 天麻 第2部分:种子与种麻生产技术规程
- DL-T5024-2020电力工程地基处理技术规程
- 2024社工(初)《社会工作实务》考试题库附答案
- 2024年兰州市高三诊断考试(一诊)数学试卷(含答案)
- 办公耗材采购服务方案(技术方案)
评论
0/150
提交评论