Форум программистов, компьютерный форум, киберфорум
Java для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/25: Рейтинг темы: голосов - 25, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 27.12.2018
Сообщений: 2

Сортировка массива методом перестановки

27.12.2018, 21:55. Показов 4623. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем здравствуйте. Только учусь программировать!
Столкнулся с проблемой!!! Имеется код. Код рабочий, но его нужно улучшить, как это сделать я не знаю. Было предложение добавить флаг, что за флаг хз. Буду признателен если кто-то поможет разобраться и допилить код.

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
public class BubbleSort {
    public int[] sort(int[] array) {
        for (int i = 0; i < array.length; i++) {
            for (int j = 0; j < array.length; j++) {
                if (array[i] < array[j]) {
                    int temp = array[i];
                    array[i] = array[j];
                    array[j] = temp;
                }
            }
        }
        return array;
    }
}
 
 
/**
*
*Это тест для проверки кода.
*
*/
 
import org.junit.Test;
import static org.hamcrest.core.Is.is;
import static org.junit.Assert.assertThat;
 
public class BubbleSortTest {
    @Test
    public void whenSortArrayWithTenElementsThenSortedArray() {
        BubbleSort buble = new BubbleSort();
        int[] mas = new int[] {1, 5, 4, 2, 3, 1, 7, 8, 0, 5};
        int[] result = buble.sort(mas);
        int[] expexted = new int[] {0, 1, 1 ,2 ,3 , 4, 5, 5, 7, 8};
        assertThat(mas,is(expexted));
        //напишите здесь тест, проверяющий сортировку массива из 10 элементов методом пузырька, например {1, 5, 4, 2, 3, 1, 7, 8, 0, 5}.
    }
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.12.2018, 21:55
Ответы с готовыми решениями:

Сортировка методом вставки n*n массива
Нужно написать сортировку на языке Джава методом вставка. Алгоритм для одномерного массива был по большей части позаимствован с википедии....

Сортировка массива методом слиянием в Java
Суть метода понятна, но не могу реализовать его в Java, очень нужна помощь.Заранее спасибо.

Сортировка массива методом выбора максимума
Помогите пожалуйста. На Java сортировка массива методом выбора максимума

9
 Аватар для NiceJacket
109 / 89 / 25
Регистрация: 02.06.2018
Сообщений: 259
27.12.2018, 22:09
код не в тэгах.

методом перестановки
но здесь представлена пузырьковая сортировка
Цитата Сообщение от Sedoy4el Посмотреть сообщение
его нужно улучшить, как это сделать я не знаю.
что вы подразумеваете под улучшением?
Было предложение добавить флаг, что за флаг хз.
о чём речь? чьё предложение?
разобраться и допилить код
опять же, в чём нужно разобраться и как его нужно допилить?
0
 Аватар для Aviz__
2736 / 2046 / 506
Регистрация: 17.02.2014
Сообщений: 9,462
28.12.2018, 10:10
Sedoy4el, вбиваешь "метод пузырька" сюда:

1
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
28.12.2018, 11:03
Цитата Сообщение от Sedoy4el
добавить флаг
Типа
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public int[] sort(int[] array) {
        boolean flag = false;
        while (flag){
            flag = false;
        for (int i = 0; i < array.length; i++) {
            for (int j = 0; j < array.length; j++) {
                if (array[i] < array[j]) {
                    int temp = array[i];
                    array[i] = array[j];
                    array[j] = temp;
                    flag = true;
                }
            }
        }
  }
        return array;
    }
Сорян за формат, с телефона...
0
0 / 0 / 0
Регистрация: 27.12.2018
Сообщений: 2
28.12.2018, 22:15  [ТС]
К сожалению Ваш код не работает
iSmokeJC
0
 Аватар для NiceJacket
109 / 89 / 25
Регистрация: 02.06.2018
Сообщений: 259
28.12.2018, 22:56
Цитата Сообщение от Sedoy4el Посмотреть сообщение
К сожалению Ваш код не работает
iSmokeJC
так вы так и не обозначили, чего надо-то?
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
28.12.2018, 23:03
Sedoy4el, я тебе примера для показал, куда воткнуть флаг.
Если уж совсем подумать/поискать влом, держи
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public int[] sort(int[] array) {
        boolean flag = true;
        while (flag) {
            flag = false;
            for (int i = 0; i < array.length - 1; i++) {
                if (array[i] > array[i + 1]) {
                    int temp = array[i];
                    array[i] = array[i + 1];
                    array[i + 1] = temp;
                    flag = true;
                }
            }
        }
        return array;
    }
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
29.12.2018, 19:43
iSmokeJC, у Вас - не сортировка перестановками, а пузырьковая сортировка.

Sedoy4el, в этом коде лишние операции. Лучше так:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public class aSort {
    public int[] sort(int[] array) {
        for (int i = 0; i < array.length-1; i++) {
            for (int j = i+1; j < array.length; j++) {
                if (array[i] < array[j]) {
                    int temp = array[i];
                    array[i] = array[j];
                    array[j] = temp;
                }
            }
        }
        return array;
    }
}
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
29.12.2018, 20:26
Цитата Сообщение от Catstail Посмотреть сообщение
лишние операции
Зато быстрей почти в 2 раза

Добавлено через 16 минут
На счет двух раз, конечно, приврал...
Catstail, Возьмем, например, массив {2, 1, 3, 4, 5, 6...99}
Мой код пробежится по массиву 2 раза, а твой - 98...

Добавлено через 27 секунд
И да, это, конечно, пузырек
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
29.12.2018, 20:42
Цитата Сообщение от iSmokeJC Посмотреть сообщение
И да, это, конечно, пузырек
- а в теме речь о сортировке перестановками. О чем я и говорю.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.12.2018, 20:42
Помогаю со студенческими работами здесь

Сортировка массива методом перестановки
Условия нет, просто нужно сделать задачу по сортировке массива методом перестановки, и что бы числа были отображены по возрастанию,...

Сортировка одномерного массива в порядке возрастания методом перестановки
Здравствуйте очень нужна ваша помощь,готовлюсь к сесии,а она в пятницу ,в visual basik 6.0 написать не совсем понял как,нужен будет код...

Сортировка по убыванию методом обмена с флагом перестановки
Реализовать сортировку по убыванию методом обмена с флагом перестановки как на картинке Есть подобная программа program...

Сортировка матрицы по возрастанию методом обмена с флагом перестановки
Отсортировать матрицу по возрастанию методом обмена с флагом перестановки согласно изображению в чём ошибка? вроде работает, но не...

Из массива символов методом перестановки сформировать заданное слово
Дано два массива символов, в каждом из которых задано слово. Проверить, можно ли из одного из них составить другое перестановкой букв, при...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru