mirror of
https://gitee.com/coder-xiaomo/algorithm-visualization
synced 2025-01-25 19:00:29 +08:00
添加冒泡排序动画;添加.gitignore
This commit is contained in:
parent
a90d2db71c
commit
cbd867e5f4
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
.VSCodeCounter
|
@ -56,6 +56,11 @@ class Sort {
|
|||||||
// console.log(Object.keys(array))
|
// console.log(Object.keys(array))
|
||||||
// console.log(array, index1, index2)
|
// console.log(array, index1, index2)
|
||||||
}
|
}
|
||||||
|
swapAnimation(id, index1, index2) {
|
||||||
|
if (index1 == index2)
|
||||||
|
return
|
||||||
|
animation.swapLinkedListItems(id, [index1, index2])
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -123,14 +128,15 @@ class QuickSort extends Sort {
|
|||||||
const pivot = left // 第一个元素的索引
|
const pivot = left // 第一个元素的索引
|
||||||
let p = left + 1
|
let p = left + 1
|
||||||
for (let i = left + 1; i <= right; i++) {
|
for (let i = left + 1; i <= right; i++) {
|
||||||
|
animation.highlightLinkedListItems(customAttr.id, [i, pivot])
|
||||||
if (array[i] < array[pivot]) {
|
if (array[i] < array[pivot]) {
|
||||||
this.swap(array, i, p)
|
this.swap(array, i, p)
|
||||||
animation.swapLinkedListItems(customAttr.id, [i, p])
|
this.swapAnimation(customAttr.id, i, p)
|
||||||
p++
|
p++
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.swap(array, pivot, p - 1)
|
this.swap(array, pivot, p - 1)
|
||||||
animation.swapLinkedListItems(customAttr.id, [pivot, p - 1])
|
this.swapAnimation(customAttr.id, pivot, p - 1)
|
||||||
|
|
||||||
// 左、右分别排序(索引超限在 sort 内部进行处理,此处无需判断)
|
// 左、右分别排序(索引超限在 sort 内部进行处理,此处无需判断)
|
||||||
this.sortWithAnimation(customAttr, array, pivot, p - 2)
|
this.sortWithAnimation(customAttr, array, pivot, p - 2)
|
||||||
@ -179,6 +185,25 @@ class BubbleSort extends Sort {
|
|||||||
|
|
||||||
return array
|
return array
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sortWithAnimation(customAttr, array) {
|
||||||
|
let sortTime = 0
|
||||||
|
let swapped
|
||||||
|
do {
|
||||||
|
swapped = false
|
||||||
|
for (let i = 1; i < array.length - sortTime; i++) {
|
||||||
|
animation.highlightLinkedListItems(customAttr.id, [i - 1, i])
|
||||||
|
if (array[i - 1] > array[i]) {
|
||||||
|
this.swap(array, i - 1, i)
|
||||||
|
this.swapAnimation(customAttr.id, i - 1, i)
|
||||||
|
swapped = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
sortTime++
|
||||||
|
} while (swapped)
|
||||||
|
|
||||||
|
return array
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -250,7 +250,8 @@ class VectorAnimation {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async swapLinkedListItems(id, [fromIndex, toIndex]) {
|
// 交换数组元素
|
||||||
|
swapLinkedListItems(id, [fromIndex, toIndex]) {
|
||||||
if (fromIndex < toIndex)
|
if (fromIndex < toIndex)
|
||||||
[fromIndex, toIndex] = [toIndex, fromIndex]
|
[fromIndex, toIndex] = [toIndex, fromIndex]
|
||||||
|
|
||||||
@ -268,7 +269,7 @@ class VectorAnimation {
|
|||||||
var deltaY = customAttr.oneUnit * 1.08
|
var deltaY = customAttr.oneUnit * 1.08
|
||||||
|
|
||||||
var animateSettings = {
|
var animateSettings = {
|
||||||
duration: 0.3,
|
duration: 0.2,
|
||||||
ease: "sine.inOut",
|
ease: "sine.inOut",
|
||||||
delay: 0,
|
delay: 0,
|
||||||
yoyo: true,
|
yoyo: true,
|
||||||
@ -293,7 +294,7 @@ class VectorAnimation {
|
|||||||
customAttr.nodes[toIndex] = tmp
|
customAttr.nodes[toIndex] = tmp
|
||||||
|
|
||||||
// console.log(customAttr.nodes)
|
// console.log(customAttr.nodes)
|
||||||
updateConsole(customAttr.nodes.toString().replaceAll(",", ", "))
|
updateConsole("当前数组为:" + customAttr.nodes.toString().replaceAll(",", ", "))
|
||||||
|
|
||||||
console.log("done")
|
console.log("done")
|
||||||
}
|
}
|
||||||
@ -322,4 +323,42 @@ class VectorAnimation {
|
|||||||
|
|
||||||
customAttr.gsapTimeline.add(timeline)
|
customAttr.gsapTimeline.add(timeline)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 高亮数组元素
|
||||||
|
highlightLinkedListItems(id, indexList) {
|
||||||
|
let linkedList = document.getElementById(id)
|
||||||
|
let customAttr = linkedList.customAttr
|
||||||
|
var gList = linkedList.childNodes
|
||||||
|
|
||||||
|
if (typeof (indexList) === "number")
|
||||||
|
indexList = [indexList]
|
||||||
|
|
||||||
|
var hightlightElementList_fill = []
|
||||||
|
var hightlightElementList_text = []
|
||||||
|
for (let i = 0; i < indexList.length; i++) {
|
||||||
|
const index = indexList[i];
|
||||||
|
hightlightElementList_fill.push(gList[index].childNodes[0])
|
||||||
|
hightlightElementList_text.push(gList[index].childNodes[1])
|
||||||
|
}
|
||||||
|
var animateSettings = {
|
||||||
|
duration: 0.2,
|
||||||
|
ease: "sine.inOut",
|
||||||
|
delay: 0,
|
||||||
|
yoyo: true,
|
||||||
|
}
|
||||||
|
|
||||||
|
let timeline = gsap.timeline({
|
||||||
|
onComplete: function () {
|
||||||
|
console.log("hightlight done")
|
||||||
|
}
|
||||||
|
}).add([
|
||||||
|
gsap.to(hightlightElementList_fill, { ...animateSettings, fill: settings.colorMap["fill_focus"] }),
|
||||||
|
gsap.to(hightlightElementList_text, { ...animateSettings, fill: settings.colorMap["text_focus"] }),
|
||||||
|
]).add([
|
||||||
|
gsap.to(hightlightElementList_fill, { ...animateSettings, fill: settings.colorMap["fill"] }),
|
||||||
|
gsap.to(hightlightElementList_text, { ...animateSettings, fill: settings.colorMap["text"] }),
|
||||||
|
])
|
||||||
|
|
||||||
|
customAttr.gsapTimeline.add(timeline)
|
||||||
|
}
|
||||||
}
|
}
|
@ -55,7 +55,17 @@ var shape = new Shape(workSpace)
|
|||||||
var animation = new VectorAnimation(workSpace)
|
var animation = new VectorAnimation(workSpace)
|
||||||
|
|
||||||
function initialize() {
|
function initialize() {
|
||||||
|
var elementId = "ele8"
|
||||||
|
d3.select("#btn_qucikSort").on("click", function () {
|
||||||
|
// 快速排序算法
|
||||||
|
var sortAlgorithm = new QuickSort(animation)
|
||||||
|
sortAlgorithm.doSortWithAnimation(elementId)
|
||||||
|
})
|
||||||
|
d3.select("#btn_bubbleSort").on("click", function () {
|
||||||
|
// 冒泡排序算法
|
||||||
|
var sortAlgorithm = new BubbleSort(animation)
|
||||||
|
sortAlgorithm.doSortWithAnimation(elementId)
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
initialize()
|
initialize()
|
||||||
@ -154,5 +164,3 @@ function getRandom(length) {
|
|||||||
// animation.swapLinkedListItems(id, [getRandom(listData.length), getRandom(listData.length)])
|
// animation.swapLinkedListItems(id, [getRandom(listData.length), getRandom(listData.length)])
|
||||||
// }
|
// }
|
||||||
|
|
||||||
var sortAlgorithm = new QuickSort(animation)
|
|
||||||
sortAlgorithm.doSortWithAnimation("ele8")
|
|
@ -27,7 +27,13 @@
|
|||||||
<div id="container" class="container">
|
<div id="container" class="container">
|
||||||
正在加载中,请稍候...
|
正在加载中,请稍候...
|
||||||
</div>
|
</div>
|
||||||
|
<div style="display: grid; place-items: center;">
|
||||||
|
<div id="control-div">
|
||||||
|
<button id="btn_qucikSort">快速排序</button>
|
||||||
|
<button id="btn_bubbleSort">冒泡排序</button>
|
||||||
|
</div>
|
||||||
<div id="console-div"></div>
|
<div id="console-div"></div>
|
||||||
|
</div>
|
||||||
<!-- <div class="header">
|
<!-- <div class="header">
|
||||||
<h1>小墨 | 算法可视化</h1>
|
<h1>小墨 | 算法可视化</h1>
|
||||||
</div>
|
</div>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user