forked from UNN/2026-rff_mp
Увеличение выборки, исправление сортировки и работы дерева
This commit is contained in:
parent
6554e2ada1
commit
a939b76273
Binary file not shown.
Binary file not shown.
Binary file not shown.
File diff suppressed because one or more lines are too long
0
stepushovgs/data-structures/source/docs/report.md
Normal file
0
stepushovgs/data-structures/source/docs/report.md
Normal file
754
stepushovgs/data-structures/source/docs/src/main.ipynb
Normal file
754
stepushovgs/data-structures/source/docs/src/main.ipynb
Normal file
File diff suppressed because one or more lines are too long
|
|
@ -1,10 +1,17 @@
|
|||
package data_struct
|
||||
|
||||
func QSort(arr []MyData, l, r int) []MyData {
|
||||
result := make([]MyData, len(arr))
|
||||
copy(result, arr)
|
||||
qSort(result, l, r)
|
||||
return result
|
||||
}
|
||||
|
||||
func qSort(arr []MyData, l, r int) []MyData {
|
||||
if l < r {
|
||||
s := Partition_Hoa(arr, l, r)
|
||||
arr = QSort(arr, l, s)
|
||||
arr = QSort(arr, s+1, r)
|
||||
arr = qSort(arr, l, s)
|
||||
arr = qSort(arr, s+1, r)
|
||||
}
|
||||
return arr
|
||||
}
|
||||
|
|
|
|||
|
|
@ -29,6 +29,12 @@ func RecordsShuffled(count int) []ds.MyData {
|
|||
data[i].Phone = genRandomPhone()
|
||||
}
|
||||
|
||||
// Перемешиваем (Fisher-Yates shuffle)
|
||||
for i := len(data) - 1; i > 0; i-- {
|
||||
j := rand.Intn(i + 1)
|
||||
data[i], data[j] = data[j], data[i]
|
||||
}
|
||||
|
||||
return data
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -44,6 +44,9 @@ func (bst *BinSearchTree) Minimum() *BSTree {
|
|||
}
|
||||
|
||||
func (root *BSTree) Minimum() *BSTree {
|
||||
if root == nil {
|
||||
return nil
|
||||
}
|
||||
if root.left == nil {
|
||||
return root
|
||||
}
|
||||
|
|
@ -54,6 +57,9 @@ func (bst *BinSearchTree) Maximum() *BSTree {
|
|||
return bst.root.Maximum()
|
||||
}
|
||||
func (root *BSTree) Maximum() *BSTree {
|
||||
if root == nil {
|
||||
return nil
|
||||
}
|
||||
if root.right == nil {
|
||||
return root
|
||||
}
|
||||
|
|
@ -194,10 +200,39 @@ Node delete(root : Node, z : T): // корень поддерев
|
|||
return root
|
||||
*/
|
||||
|
||||
func (bst *BinSearchTree) Height() int {
|
||||
if bst.root == nil {
|
||||
return 0
|
||||
}
|
||||
return bst.root.height()
|
||||
}
|
||||
|
||||
// height возвращает высоту поддерева (для BSTree)
|
||||
func (node *BSTree) height() int {
|
||||
if node == nil {
|
||||
return 0
|
||||
}
|
||||
|
||||
leftHeight := node.left.height()
|
||||
rightHeight := node.right.height()
|
||||
|
||||
// Высота = 1 (текущий узел) + максимум из высот поддеревьев
|
||||
if leftHeight > rightHeight {
|
||||
return leftHeight + 1
|
||||
}
|
||||
return rightHeight + 1
|
||||
}
|
||||
|
||||
func (bst *BinSearchTree) Delete(targetName string) bool {
|
||||
if bst.root == nil {
|
||||
return false
|
||||
}
|
||||
|
||||
_, found := bst.Search(targetName)
|
||||
if !found {
|
||||
return false
|
||||
}
|
||||
|
||||
bst.root = bst.root.delete(targetName)
|
||||
return true
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,199 +1,379 @@
|
|||
Structure,Mode,Operation,Time
|
||||
Связный список,Случайный,Вставка,0.047621
|
||||
Связный список,Случайный,Поиск,0.003505
|
||||
Связный список,Случайный,Удаление,0.005502
|
||||
Связный список,Случайный,Вставка,0.048707
|
||||
Связный список,Случайный,Поиск,0.003505
|
||||
Связный список,Случайный,Удаление,0.006007
|
||||
Связный список,Случайный,Вставка,0.048086
|
||||
Связный список,Случайный,Поиск,0.003546
|
||||
Связный список,Случайный,Удаление,0.006606
|
||||
Связный список,Случайный,Вставка,0.049133
|
||||
Связный список,Случайный,Поиск,0.003018
|
||||
Связный список,Случайный,Удаление,0.006084
|
||||
Связный список,Случайный,Вставка,0.048328
|
||||
Связный список,Случайный,Поиск,0.003524
|
||||
Связный список,Случайный,Удаление,0.007066
|
||||
Связный список,Случайный,Вставка,0.047057
|
||||
Связный список,Случайный,Поиск,0.003518
|
||||
Связный список,Случайный,Удаление,0.006054
|
||||
Связный список,Случайный,Вставка,0.047979
|
||||
Связный список,Случайный,Поиск,0.003604
|
||||
Связный список,Случайный,Удаление,0.006039
|
||||
Связный список,Случайный,Вставка,0.047694
|
||||
Связный список,Случайный,Поиск,0.004520
|
||||
Связный список,Случайный,Удаление,0.005522
|
||||
Связный список,Случайный,Вставка,0.047864
|
||||
Связный список,Случайный,Поиск,0.003514
|
||||
Связный список,Случайный,Удаление,0.006814
|
||||
Связный список,Случайный,Вставка,0.048523
|
||||
Связный список,Случайный,Поиск,0.002611
|
||||
Связный список,Случайный,Удаление,0.006122
|
||||
Связный список,Случайный,Вставка (среднее),0.048099
|
||||
Связный список,Случайный,Поиск (среднее),0.003486
|
||||
Связный список,Случайный,Удаление (среднее),0.006181
|
||||
Связный список,Отсортированный,Вставка,0.046193
|
||||
Связный список,Отсортированный,Поиск,0.004520
|
||||
Связный список,Отсортированный,Удаление,0.005769
|
||||
Связный список,Отсортированный,Вставка,0.048112
|
||||
Связный список,Отсортированный,Поиск,0.003001
|
||||
Связный список,Отсортированный,Удаление,0.007026
|
||||
Связный список,Отсортированный,Вставка,0.047699
|
||||
Связный список,Отсортированный,Поиск,0.003503
|
||||
Связный список,Отсортированный,Удаление,0.006515
|
||||
Связный список,Отсортированный,Вставка,0.047867
|
||||
Связный список,Отсортированный,Поиск,0.003509
|
||||
Связный список,Отсортированный,Удаление,0.006001
|
||||
Связный список,Отсортированный,Вставка,0.047622
|
||||
Связный список,Отсортированный,Поиск,0.003001
|
||||
Связный список,Отсортированный,Удаление,0.006008
|
||||
Связный список,Отсортированный,Вставка,0.047737
|
||||
Связный список,Отсортированный,Поиск,0.003546
|
||||
Связный список,Отсортированный,Удаление,0.005514
|
||||
Связный список,Отсортированный,Вставка,0.048361
|
||||
Связный список,Отсортированный,Поиск,0.003012
|
||||
Связный список,Отсортированный,Удаление,0.005328
|
||||
Связный список,Отсортированный,Вставка,0.049622
|
||||
Связный список,Отсортированный,Поиск,0.003510
|
||||
Связный список,Отсортированный,Удаление,0.005522
|
||||
Связный список,Отсортированный,Вставка,0.048137
|
||||
Связный список,Отсортированный,Поиск,0.003518
|
||||
Связный список,Отсортированный,Удаление,0.005531
|
||||
Связный список,Отсортированный,Вставка,0.048927
|
||||
Связный список,Отсортированный,Поиск,0.004004
|
||||
Связный список,Отсортированный,Удаление,0.005470
|
||||
Связный список,Отсортированный,Вставка (среднее),0.048028
|
||||
Связный список,Отсортированный,Поиск (среднее),0.003512
|
||||
Связный список,Отсортированный,Удаление (среднее),0.005869
|
||||
Хеш таблица,Случайный,Вставка,0.001504
|
||||
Связный список,Случайный,Вставка,0.193393
|
||||
Связный список,Случайный,Поиск,0.023572
|
||||
Связный список,Случайный,Удаление,0.013566
|
||||
Связный список,Случайный,Вставка,0.193837
|
||||
Связный список,Случайный,Поиск,0.023969
|
||||
Связный список,Случайный,Удаление,0.013580
|
||||
Связный список,Случайный,Вставка,0.190963
|
||||
Связный список,Случайный,Поиск,0.023944
|
||||
Связный список,Случайный,Удаление,0.013505
|
||||
Связный список,Случайный,Вставка,0.194440
|
||||
Связный список,Случайный,Поиск,0.022179
|
||||
Связный список,Случайный,Удаление,0.015040
|
||||
Связный список,Случайный,Вставка,0.191873
|
||||
Связный список,Случайный,Поиск,0.023604
|
||||
Связный список,Случайный,Удаление,0.014556
|
||||
Связный список,Случайный,Вставка,0.191788
|
||||
Связный список,Случайный,Поиск,0.023570
|
||||
Связный список,Случайный,Удаление,0.013037
|
||||
Связный список,Случайный,Вставка,0.192362
|
||||
Связный список,Случайный,Поиск,0.023050
|
||||
Связный список,Случайный,Удаление,0.013997
|
||||
Связный список,Случайный,Вставка,0.191223
|
||||
Связный список,Случайный,Поиск,0.023778
|
||||
Связный список,Случайный,Удаление,0.013582
|
||||
Связный список,Случайный,Вставка,0.191326
|
||||
Связный список,Случайный,Поиск,0.023035
|
||||
Связный список,Случайный,Удаление,0.013183
|
||||
Связный список,Случайный,Вставка,0.191919
|
||||
Связный список,Случайный,Поиск,0.023584
|
||||
Связный список,Случайный,Удаление,0.013988
|
||||
Связный список,Случайный,Вставка,0.190009
|
||||
Связный список,Случайный,Поиск,0.022013
|
||||
Связный список,Случайный,Удаление,0.014679
|
||||
Связный список,Случайный,Вставка,0.191010
|
||||
Связный список,Случайный,Поиск,0.024724
|
||||
Связный список,Случайный,Удаление,0.015116
|
||||
Связный список,Случайный,Вставка,0.192876
|
||||
Связный список,Случайный,Поиск,0.023690
|
||||
Связный список,Случайный,Удаление,0.021114
|
||||
Связный список,Случайный,Вставка,0.202786
|
||||
Связный список,Случайный,Поиск,0.023466
|
||||
Связный список,Случайный,Удаление,0.014063
|
||||
Связный список,Случайный,Вставка,0.191339
|
||||
Связный список,Случайный,Поиск,0.022909
|
||||
Связный список,Случайный,Удаление,0.014661
|
||||
Связный список,Случайный,Вставка,0.189898
|
||||
Связный список,Случайный,Поиск,0.023056
|
||||
Связный список,Случайный,Удаление,0.013592
|
||||
Связный список,Случайный,Вставка,0.195372
|
||||
Связный список,Случайный,Поиск,0.023198
|
||||
Связный список,Случайный,Удаление,0.013819
|
||||
Связный список,Случайный,Вставка,0.191713
|
||||
Связный список,Случайный,Поиск,0.023542
|
||||
Связный список,Случайный,Удаление,0.012883
|
||||
Связный список,Случайный,Вставка,0.190514
|
||||
Связный список,Случайный,Поиск,0.023745
|
||||
Связный список,Случайный,Удаление,0.015012
|
||||
Связный список,Случайный,Вставка,0.189447
|
||||
Связный список,Случайный,Поиск,0.023544
|
||||
Связный список,Случайный,Удаление,0.014063
|
||||
Связный список,Случайный,Вставка (среднее),0.192404
|
||||
Связный список,Случайный,Поиск (среднее),0.023409
|
||||
Связный список,Случайный,Удаление (среднее),0.014352
|
||||
Связный список,Отсортированный,Вставка,0.193078
|
||||
Связный список,Отсортированный,Поиск,0.033527
|
||||
Связный список,Отсортированный,Удаление,0.022597
|
||||
Связный список,Отсортированный,Вставка,0.190167
|
||||
Связный список,Отсортированный,Поиск,0.032657
|
||||
Связный список,Отсортированный,Удаление,0.022773
|
||||
Связный список,Отсортированный,Вставка,0.191660
|
||||
Связный список,Отсортированный,Поиск,0.034012
|
||||
Связный список,Отсортированный,Удаление,0.022709
|
||||
Связный список,Отсортированный,Вставка,0.191970
|
||||
Связный список,Отсортированный,Поиск,0.032553
|
||||
Связный список,Отсортированный,Удаление,0.022828
|
||||
Связный список,Отсортированный,Вставка,0.194583
|
||||
Связный список,Отсортированный,Поиск,0.034762
|
||||
Связный список,Отсортированный,Удаление,0.022843
|
||||
Связный список,Отсортированный,Вставка,0.192641
|
||||
Связный список,Отсортированный,Поиск,0.033173
|
||||
Связный список,Отсортированный,Удаление,0.022690
|
||||
Связный список,Отсортированный,Вставка,0.194789
|
||||
Связный список,Отсортированный,Поиск,0.033526
|
||||
Связный список,Отсортированный,Удаление,0.022985
|
||||
Связный список,Отсортированный,Вставка,0.191488
|
||||
Связный список,Отсортированный,Поиск,0.032518
|
||||
Связный список,Отсортированный,Удаление,0.023373
|
||||
Связный список,Отсортированный,Вставка,0.203929
|
||||
Связный список,Отсортированный,Поиск,0.034133
|
||||
Связный список,Отсортированный,Удаление,0.023423
|
||||
Связный список,Отсортированный,Вставка,0.193756
|
||||
Связный список,Отсортированный,Поиск,0.033023
|
||||
Связный список,Отсортированный,Удаление,0.022845
|
||||
Связный список,Отсортированный,Вставка,0.195554
|
||||
Связный список,Отсортированный,Поиск,0.032817
|
||||
Связный список,Отсортированный,Удаление,0.023482
|
||||
Связный список,Отсортированный,Вставка,0.193150
|
||||
Связный список,Отсортированный,Поиск,0.033271
|
||||
Связный список,Отсортированный,Удаление,0.022587
|
||||
Связный список,Отсортированный,Вставка,0.192696
|
||||
Связный список,Отсортированный,Поиск,0.033454
|
||||
Связный список,Отсортированный,Удаление,0.022527
|
||||
Связный список,Отсортированный,Вставка,0.192065
|
||||
Связный список,Отсортированный,Поиск,0.033382
|
||||
Связный список,Отсортированный,Удаление,0.022786
|
||||
Связный список,Отсортированный,Вставка,0.191702
|
||||
Связный список,Отсортированный,Поиск,0.031664
|
||||
Связный список,Отсортированный,Удаление,0.023819
|
||||
Связный список,Отсортированный,Вставка,0.194042
|
||||
Связный список,Отсортированный,Поиск,0.032380
|
||||
Связный список,Отсортированный,Удаление,0.023181
|
||||
Связный список,Отсортированный,Вставка,0.190397
|
||||
Связный список,Отсортированный,Поиск,0.033168
|
||||
Связный список,Отсортированный,Удаление,0.022893
|
||||
Связный список,Отсортированный,Вставка,0.191636
|
||||
Связный список,Отсортированный,Поиск,0.032367
|
||||
Связный список,Отсортированный,Удаление,0.022448
|
||||
Связный список,Отсортированный,Вставка,0.193131
|
||||
Связный список,Отсортированный,Поиск,0.032905
|
||||
Связный список,Отсортированный,Удаление,0.022932
|
||||
Связный список,Отсортированный,Вставка,0.191676
|
||||
Связный список,Отсортированный,Поиск,0.032851
|
||||
Связный список,Отсортированный,Удаление,0.022315
|
||||
Связный список,Отсортированный,Вставка (среднее),0.193206
|
||||
Связный список,Отсортированный,Поиск (среднее),0.033107
|
||||
Связный список,Отсортированный,Удаление (среднее),0.022902
|
||||
Хеш таблица,Случайный,Вставка,0.002119
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.002047
|
||||
Хеш таблица,Случайный,Вставка,0.003507
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.002010
|
||||
Хеш таблица,Случайный,Вставка,0.002563
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.002005
|
||||
Хеш таблица,Случайный,Вставка,0.003023
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.002513
|
||||
Хеш таблица,Случайный,Вставка,0.003513
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.001505
|
||||
Хеш таблица,Случайный,Вставка,0.002516
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.002529
|
||||
Хеш таблица,Случайный,Вставка,0.003369
|
||||
Хеш таблица,Случайный,Поиск,0.001002
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.002091
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.001504
|
||||
Хеш таблица,Случайный,Вставка,0.003654
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.002023
|
||||
Хеш таблица,Случайный,Вставка,0.003102
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.002429
|
||||
Хеш таблица,Случайный,Вставка,0.003008
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка (среднее),0.002007
|
||||
Хеш таблица,Случайный,Поиск (среднее),0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.003997
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.001580
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.005478
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.002015
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.003410
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.002158
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.003586
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.003123
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка,0.003011
|
||||
Хеш таблица,Случайный,Поиск,0.000000
|
||||
Хеш таблица,Случайный,Удаление,0.000000
|
||||
Хеш таблица,Случайный,Вставка (среднее),0.003041
|
||||
Хеш таблица,Случайный,Поиск (среднее),0.000050
|
||||
Хеш таблица,Случайный,Удаление (среднее),0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002005
|
||||
Хеш таблица,Отсортированный,Вставка,0.003208
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.001282
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.001504
|
||||
Хеш таблица,Отсортированный,Вставка,0.001015
|
||||
Хеш таблица,Отсортированный,Вставка,0.003095
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002016
|
||||
Хеш таблица,Отсортированный,Вставка,0.002048
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.001505
|
||||
Хеш таблица,Отсортированный,Вставка,0.003991
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002016
|
||||
Хеш таблица,Отсортированный,Поиск,0.000502
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002009
|
||||
Хеш таблица,Отсортированный,Вставка,0.002006
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.001068
|
||||
Хеш таблица,Отсортированный,Вставка,0.003505
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002516
|
||||
Хеш таблица,Отсортированный,Вставка,0.003013
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002505
|
||||
Хеш таблица,Отсортированный,Вставка,0.002423
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.001102
|
||||
Хеш таблица,Отсортированный,Вставка,0.003121
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000503
|
||||
Хеш таблица,Отсортированный,Вставка,0.002511
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка (среднее),0.001794
|
||||
Хеш таблица,Отсортированный,Поиск (среднее),0.000050
|
||||
Хеш таблица,Отсортированный,Удаление (среднее),0.000150
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.304277
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.007550
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.013564
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.297918
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.007167
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.014539
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.300777
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.008009
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.015144
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.307342
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.008307
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.013577
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.301149
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.007792
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.012897
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.304480
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.006521
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.014053
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.299029
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.007552
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.013073
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.304265
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.006518
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.014555
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.297193
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.007529
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.014092
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.300190
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.006525
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.014096
|
||||
Бинарное дерево поиска,Случайный,Вставка (среднее),0.301662
|
||||
Бинарное дерево поиска,Случайный,Поиск (среднее),0.007347
|
||||
Бинарное дерево поиска,Случайный,Удаление (среднее),0.013959
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.317393
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.007554
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.013053
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.301527
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.006503
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.014265
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.300625
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.008043
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.013068
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.303297
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.007039
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.013601
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.300072
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.008539
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.013535
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.298420
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.007256
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.013550
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.298652
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.008040
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.013532
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.299859
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.007577
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.013575
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.307201
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.008025
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.014125
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.304290
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.007040
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.013611
|
||||
Бинарное дерево поиска,Отсортированный,Вставка (среднее),0.303134
|
||||
Бинарное дерево поиска,Отсортированный,Поиск (среднее),0.007562
|
||||
Бинарное дерево поиска,Отсортированный,Удаление (среднее),0.013591
|
||||
Хеш таблица,Отсортированный,Вставка,0.003011
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002003
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.001341
|
||||
Хеш таблица,Отсортированный,Вставка,0.001513
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.004485
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002740
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002310
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002506
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.002515
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.003073
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка,0.004169
|
||||
Хеш таблица,Отсортированный,Поиск,0.000000
|
||||
Хеш таблица,Отсортированный,Удаление,0.000000
|
||||
Хеш таблица,Отсортированный,Вставка (среднее),0.002862
|
||||
Хеш таблица,Отсортированный,Поиск (среднее),0.000000
|
||||
Хеш таблица,Отсортированный,Удаление (среднее),0.000147
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.004626
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.001014
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.004910
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.005058
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.001009
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.004521
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.005904
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.001025
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.005221
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.001066
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.005843
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.007343
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000503
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000516
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.006171
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000512
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.005454
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.001009
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.006885
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.001451
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.006402
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.001009
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.004521
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.001055
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.005170
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.001503
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.005615
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.001001
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.005535
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.005566
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.001004
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.004022
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.001010
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.004053
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.001079
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка,0.004512
|
||||
Бинарное дерево поиска,Случайный,Поиск,0.000000
|
||||
Бинарное дерево поиска,Случайный,Удаление,0.000000
|
||||
Бинарное дерево поиска,Случайный,Вставка (среднее),0.005367
|
||||
Бинарное дерево поиска,Случайный,Поиск (среднее),0.000334
|
||||
Бинарное дерево поиска,Случайный,Удаление (среднее),0.000454
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.901140
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.055198
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.068970
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.901221
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.055432
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.067588
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.875497
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.055297
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.068742
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.894420
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.054808
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.068112
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.879010
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.054503
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.068600
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.873702
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.055239
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.067484
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.889047
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.066586
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.071171
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.881977
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.059766
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.069783
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.890244
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.054863
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.069397
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.871035
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.055970
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.065886
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.873882
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.056181
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.069140
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.932258
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.055037
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.066576
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.875622
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.055679
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.068214
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.871718
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.055748
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.067876
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.872458
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.054689
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.068765
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.871178
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.054816
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.067832
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.876907
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.054184
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.068164
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.868001
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.054167
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.068493
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.879394
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.058173
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.068654
|
||||
Бинарное дерево поиска,Отсортированный,Вставка,0.868870
|
||||
Бинарное дерево поиска,Отсортированный,Поиск,0.055234
|
||||
Бинарное дерево поиска,Отсортированный,Удаление,0.068269
|
||||
Бинарное дерево поиска,Отсортированный,Вставка (среднее),0.882379
|
||||
Бинарное дерево поиска,Отсортированный,Поиск (среднее),0.056078
|
||||
Бинарное дерево поиска,Отсортированный,Удаление (среднее),0.068386
|
||||
|
|
|
|||
|
|
|
@ -16,11 +16,11 @@ import (
|
|||
)
|
||||
|
||||
const (
|
||||
countUsers = 10_000
|
||||
countRepeat = 10
|
||||
countRandomSearch = 200
|
||||
countNotExitstSearch = 100
|
||||
countDeletes = 500
|
||||
countUsers = 20_000
|
||||
countRepeat = 20
|
||||
countRandomSearch = 1000
|
||||
countNotExitstSearch = 500
|
||||
countDeletes = 1000
|
||||
)
|
||||
|
||||
type TestData struct {
|
||||
|
|
@ -56,8 +56,9 @@ func NewBinSearchTree() DataStructure {
|
|||
|
||||
func uniqueElements(data []ds.MyData) []ds.MyData {
|
||||
res := make([]ds.MyData, 0, len(data))
|
||||
isUnique := true
|
||||
|
||||
for _, el := range data {
|
||||
isUnique := true
|
||||
for _, resEl := range res {
|
||||
if el == resEl {
|
||||
isUnique = false
|
||||
|
|
@ -74,6 +75,7 @@ func uniqueElements(data []ds.MyData) []ds.MyData {
|
|||
|
||||
func GenerateTestData() TestData {
|
||||
items := dg.RecordsShuffled(countUsers)
|
||||
// fmt.Println("isSorted:", isSorted(items))
|
||||
itemsSort := ds.QSort(items, 0, len(items)-1)
|
||||
|
||||
uniqueItems := uniqueElements(items)
|
||||
|
|
@ -174,6 +176,14 @@ func testForData(nameStruct, mode string, factory StructureFactory, data_insert,
|
|||
insertTime := testOnesInsert(structure, data_insert)
|
||||
averageTimeInsert += insertTime
|
||||
|
||||
// Отладочная информация для бинарного дерева (проверка на вырождение)
|
||||
if bst, ok := structure.(*bst.BinSearchTree); ok {
|
||||
fmt.Printf(
|
||||
"Высота дерева: %d, элементов: %d\n",
|
||||
bst.Height(), bst.Len(),
|
||||
)
|
||||
}
|
||||
|
||||
BenchRes = append(BenchRes, csvwriter.BenchmarkResult{
|
||||
Structure: nameStruct,
|
||||
Mode: mode,
|
||||
|
|
@ -235,9 +245,21 @@ func testForData(nameStruct, mode string, factory StructureFactory, data_insert,
|
|||
csvwriter.AppendRaw(BenchRes)
|
||||
}
|
||||
|
||||
func isSorted(data []ds.MyData) bool {
|
||||
for i := 0; i < len(data)-1; i++ {
|
||||
if data[i].Name > data[i+1].Name {
|
||||
return false
|
||||
}
|
||||
}
|
||||
return true
|
||||
}
|
||||
|
||||
func Test(nameStruct string, factory StructureFactory) {
|
||||
data := GenerateTestData()
|
||||
|
||||
// fmt.Println("items", isSorted(data.Items))
|
||||
// fmt.Println("items sort", isSorted(data.ItemsSorted))
|
||||
|
||||
testForData(nameStruct, "Случайный", factory, data.Items, data.Search, data.ToDelete)
|
||||
|
||||
testForData(nameStruct, "Отсортированный", factory, data.ItemsSorted, data.Search, data.ToDelete)
|
||||
|
|
@ -253,4 +275,7 @@ func main() {
|
|||
Test("Связный список", NewLinkedList)
|
||||
Test("Хеш таблица", NewHashTable)
|
||||
Test("Бинарное дерево поиска", NewBinSearchTree)
|
||||
|
||||
// fmt.Println("User_0001" < "User_00100")
|
||||
// fmt.Println(isSorted(dg.RecordsShuffled(10000)))
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user