Форум программистов, компьютерный форум, киберфорум
Java
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
 Аватар для BirviZ
1 / 1 / 2
Регистрация: 11.10.2015
Сообщений: 82

Сравнение скорости двух алгоритмов сортировки jUnit

10.12.2016, 13:55. Показов 1821. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Решил потестить алгоритмы, заодно поучить jUnit.

Вот класс сортировок,
Java
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
public class Sort {
 
    private int[] array;
 
    public Sort(int[] array) {
        this.array = array;
    }
 
    public void perebor() {
        for (int i = 0; i < array.length; ++i) {
            for (int j = i; j < array.length;  ++j) {
                if (array[j] < array[i]) {
                    swap(j, i);
                }
            }
        }
    }
 
    public void bubble() {
        boolean change;
        do {
            change = false;
            for (int i = 0; i < array.length-1; ++i) {
                if (array[i] > array[i+1]) {
                    swap(i, i+1);
                    change = true;
                }
            }
        } while (change);
    }
 
    private void swap(int firstIndex, int secondIndex) {
        int temp = array[firstIndex];
        array[firstIndex] = array[secondIndex];
        array[secondIndex] = temp;
    }
 
    public int[] getArray() {
        return array;
    }
}
И класс тестов
Java
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
import org.junit.Before;
import org.junit.Test;
 
public class SortTest {
    private final int LENGTH = 50000;
    private Sort sort;
    private int[] array = new int[LENGTH];
 
    @Before
    public void init() {
        for (int i = 0; i < array.length; ++i) {
            array[i] = (int)(Math.random() * LENGTH);
        }
 
        sort = new Sort(array);
    }
 
    @Test(timeout = 30000)
    public void test_perebor() {
        sort.perebor();
    }
 
    @Test(timeout = 30000)
    public void test_bubble() {
        sort.bubble();
    }
}
Так вот. Пузырьковый метод всегда быстрее.
У меня вопрос. Или я не правильно понимаю алгоритмы сортировки или я не правильно пишу тесты.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.12.2016, 13:55
Ответы с готовыми решениями:

Оценка скорости работы алгоритмов сортировки
Создайте массив из 10 000 элементов, заполните случайными значениями от 0 до 10 000. Измерьте время выполнения каждого алгоритма и...

Графики скорости работы алгоритмов сортировки
Добрый вечер всем. Задали сделать график по 3м сортировкам. Количество элементов в массиве постоянно изменяется. 1 точка- 50 000...

Сравнение алгоритмов сортировки
Написать программу сортировок массивов указанными в таблице методами. Исходные массивы заполняются случайными числами. Определить...

3
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
10.12.2016, 14:48
А какой второй алгоритм сортировки?
0
 Аватар для BirviZ
1 / 1 / 2
Регистрация: 11.10.2015
Сообщений: 82
10.12.2016, 14:50  [ТС]
Первый перебор, второй пузырек
void perebor() void bubble()
0
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
10.12.2016, 15:52
Что за перебор? Никогда не слышал о такой сортировке.
Можете дать описание?
Почему вы думаете, что пузырёк должен быть медленнее перебора?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.12.2016, 15:52
Помогаю со студенческими работами здесь

Алгоритмы сортировки,сравнение алгоритмов
Всем привет у меня такое задание Составить программы благоустройства первых N, N ≤12, элементов массива X. Вид сортировки, а...

Сравнение алгоритмов сортировки массива
Всем доброго времени суток Получил задание в университете, выполнил его. Результатом не очень доволен, хотя явных ошибок не вижу... ...

Сравнение алгоритмов сортировки (выбором и пузырьком)
создать программу для сравнения алгоритмов сортировки (Выбором и Пузырьком)т.е. чтоб выдавал время построения массива.Помогите очень...

Сравнение алгоритмов сортировки ... алгоритм Шелла
Вопрос такой, для лабораторной работы нужно сравнить три алгоритма сортировки чисел ... так вот измеряю время работы : double start...

Сравнение алгоритмов сортировки Хоара и std::sort
Собственно в универе было дано задание, написать программу которая принимает на вход из файла в структуру имя - производитель-цена и...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru