Форум программистов, компьютерный форум, киберфорум
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
54 / 71 / 20
Регистрация: 26.06.2013
Сообщений: 194

Ошибка в реализации сортировки слиянием

25.12.2013, 17:38. Показов 635. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Перевел с паскаля на vb.net сортировку вставками
Вот что получилось
VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
  Sub MergeSort(ByRef d() As Double)
        Dim m, n, k As Long
        m = d.Length - 1
        If m > 1 Then
            n = m \ 2
            Dim b(n) As Double
            For i1 As Long = 1 To n
                b(i1) = d(i1)
            Next
            k = m - n
            MergeSort(b) 
            Dim c(k) As Double
            For i1 As Long = 1 To K
                c(i1) = d(n + i1)
            Next
            MergeSort(c)
            Dim i, j, l As Long
            i = 1
            j = 1
            l = 1
            While i <= n And j <= k
                If b(i) < c(j) Then
                    d(l) = b(i)
                    i += 1
                Else
                    d(l) = c(j)
                    j += 1
                End If
                l += 1
            End While
            While i <= n
                d(l) = b(i)
                l += 1
                i += 1
            End While
            While j <= k
                d(l) = c(j)
                l += 1
                j += 1
            End While
        End If
 
    End Sub
Но он предназначен только для массива с нумерацией от 1
Переделал для того что бы работал с нулевого элемента но в результате получаю массив одинаковых чисел.
В чем ошибка?
VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
 Sub MergeSort(ByRef d() As Double)
        Dim m, n, k As Long
        m = d.Length
        If m > 1 Then
            n = m \ 2 - 1
            Dim b(n) As Double
            For i1 As Long = 0 To n
                b(i1) = d(i1)
            Next
            k = m - n - 1
            MergeSort(b) 
            Dim c(k - 1) As Double
            For i1 As Long = 1 To K
                c(i1 - 1) = d(n + i1)
            Next
            MergeSort(c)
            Dim i, j, l As Long
            While i < n And j < k
                If b(i) < c(j) Then
                    d(l) = b(i)
                    i += 1
                Else
                    d(l) = c(j)
                    j += 1
                End If
                l += 1
            End While
            While i < n
                d(l) = b(i)
                l += 1
                i += 1
            End While
            While j < k
                d(l) = c(j)
                l += 1
                j += 1
            End While
        End If
 
    End Sub
Добавлено через 7 минут
Извиняюсь, сортировка слиянием, а не вставками
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.12.2013, 17:38
Ответы с готовыми решениями:

Ошибка в коде сортировки слиянием
Вобщем, я реализовал рекурсивную сортировку слиянием (Merge Sort), но она работает за O(N), а должна за O(N log N), помогите найти ошибку в...

Ошибка при написании сортировки слиянием
Доброго времени суток. я писал сортировку слиянием. Вроде всё как надо, по алгоритму но на одном участке кода ошибка.Не объясните в чём она...

Ошибка в реализации сортировки выбором
Опять не вижу ошибки в коде. Выдает ту же числовую последовательность program sortirovka implicit none real(8) item,cnt Integer,...

1
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 1
03.06.2015, 15:49
Делал без функции, но задача была аналогичной, как-то так)

P.S.: Размер массива известен из условия моей задачи(20 элементов в диапазоне от 10 до 90), но в общем-то я думаю, несложно будет переделать под универсальный вариант, когда размерность задает пользователь.


VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
Public Class Form1
 
    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        Dim A(19), B(9), C(9), D(19) As Integer
        Dim n, i, j, k, t, tmp As Integer
        n = 20
        TextBox1.Text = "Исходный массив: " + vbCrLf
        For i = 0 To n - 1
            A(i) = 10 + (90 - 10) * Rnd()
            TextBox1.Text += CStr(A(i)) + Space(2)
        Next i
        k = n / 2
        For i = 0 To k - 1
            B(i) = A(i)
            C(i) = A(n - 1 - i)
        Next i
 
        For j = 0 To k      'Сортировка первой половины'
            For i = 0 To k - 2
                If B(i) < B(i + 1) Then
                    tmp = B(i)
                    B(i) = B(i + 1)
                    B(i + 1) = tmp
                    tmp = 0
                End If
            Next i
        Next j
 
        For j = 0 To k     'Сортировка второй половины'
            For i = 0 To k - 2
                If C(i) < C(i + 1) Then
                    tmp = C(i)
                    C(i) = C(i + 1)
                    C(i + 1) = tmp
                    tmp = 0
                End If
            Next i
        Next j
 
        i = 0
        j = 0
        t = 0
 
        Do While (i <= k - 1) And (j <= k - 1)    'Слияние 2х отсортированных массивов'
            If B(i) > C(j) Then
                D(t) = B(i)
                i += 1
            Else
                D(t) = C(j)
                j += 1
            End If
            t += 1
        Loop
 
        While i <= k - 1
            D(t) = B(i)
            t += 1
            i += 1
        End While
 
        While j <= k - 1
            D(t) = C(j)
            t += 1
            j += 1
        End While
 
        TextBox1.Text += vbCrLf + "Отсортированный массив: " + vbCrLf
        For i = 0 To n - 1
            TextBox1.Text += CStr(D(i)) + Space(2)
        Next i
    End Sub
End Class
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.06.2015, 15:49
Помогаю со студенческими работами здесь

Ошибка в реализации быстрой сортировки
Сортирует список быстрой сортировкой, результирующий список - Ls. Вместо результата при вызове цели выводится false... Что это значит, и...

Ошибка StackOverflowException при реализации быстрой сортировки
Здравствуйте, уже несколько дней пытаюсь разобраться в чём дело. Выдаёт ошибку StackOverflowException Сам код: class Program { ...

Алгортим сортировки слиянием
Доброго времени суток, решил попрактиковаться в алгоритмах, дошел до сортировки слиянием, и что-то у меня не идет. Подскажите, что я...

Алгоритм сортировки слиянием
Ребятки помоги! Понять что здесь не так: public static IEnumerable&lt;T&gt; MSort&lt;T&gt;(this IEnumerable&lt;T&gt; list) where T :...

Процедура сортировки слиянием
Может кто помочь,заранее благодарен.Напишите на псевдокоде процедуры сортировки слиянием и покажите как она работает на входе А =


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru