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

Сколько обменов сделает алгоритм пузырьковой сортировки

30.05.2021, 14:26. Показов 5593. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
здравствуйте, можете пожалуйста подсказать как связать N и N чисел в задача, вся программа у меня есть, но тест не проходит так как не использовал первое число
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
def bubble_sort(a):
    n = len(a)
    unordered = True
    while unordered:
        unordered = False
        for j in range(n - 1):
            if a[j] > a[j + 1]:
                a[j], a[j + 1] = a[j + 1], a[j]
                unordered = True
                ls.append(a)
        n -= 1
ls = []
a = input().split()
bubble_sort(a)
print(len(ls))
Определите, сколько обменов сделает алгоритм пузырьковой сортировки по возрастанию для данного массива.
ввод:
5
1 2 3 4 5
вывод:
0
решать не прошу, подскажите где прочесть
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.05.2021, 14:26
Ответы с готовыми решениями:

Функция реализующая алгоритм пузырьковой сортировки (Bubble Sort)
Напишите функцию Python, реализующую алгоритм пузырьковой сортировки (Bubble Sort). Опишите алгоритм

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

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

9
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
30.05.2021, 14:40
Alexander89, для начала надо написать "пузырёк", а потом уже думать как обмены считать (там буквально 1 строку добавить) + используйте теги форматирования кода
0
0 / 0 / 0
Регистрация: 22.02.2021
Сообщений: 28
30.05.2021, 14:56  [ТС]
у меня вверху пузырек + считает количество операций
0
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
30.05.2021, 14:59
Python
1
2
3
4
5
6
7
8
9
10
# step 1
def bubble_sort(a):
    for _ in range(len(a)):
        for i in range(1, len(a)):
            if a[i] < a[i-1]:
                a[i], a[i-1] = a[i-1], a[i]
 
 
a = map(int, input().split())
print(bubble_sort(a))
Что нужно добавить что-бы получить нужный ответ?
Кликните здесь для просмотра всего текста
Python
1
2
3
4
5
6
7
8
9
# step 2
def bubble_sort(a):
    ans = 0
    for _ in range(len(a)):
        for i in range(1, len(a)):
            if a[i] < a[i-1]:
                a[i], a[i-1] = a[i-1], a[i]
                ans += 1
    return ans


Добавлено через 2 минуты
Alexander89, да, старость не радость, не увидел
Цитата Сообщение от Alexander89 Посмотреть сообщение
тест не проходит так как не использовал первое число
Но тест не проходит так как вы сравниваете строки а не числа
Цитата Сообщение от Alexander89 Посмотреть сообщение
a = input().split()
bubble_sort(a)
0
0 / 0 / 0
Регистрация: 22.02.2021
Сообщений: 28
30.05.2021, 15:00  [ТС]
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
def bubble_sort(a):
n = len(a)
unordered = True
while unordered:
unordered = False
for j in range(n - 1):
if a[j] > a[j + 1]:
a[j], a[j + 1] = a[j + 1], a[j]
unordered = True
ls.append(a)
n -= 1
ls = []
a = input().split()
bubble_sort(a)
print(len(ls))
0
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
30.05.2021, 15:07
Отмена, 1ю строку надо просто заигнорить

Добавлено через 52 секунды
Цитата Сообщение от Alexander89 Посмотреть сообщение
a = input().split()
ты тут 1 число получаешь - "5"

Добавлено через 3 минуты
Ещё можешь slice взять

Python
1
2
n = int(input())
bubble_sort(a[:n])
, если боишься что может быть больше чисел

Добавлено через 2 минуты
Alexander89, то что ты тегом воспользовался - это хорошо, но поздно, отсупы слетели всё равно, оно не запустится на интепретаторе
0
0 / 0 / 0
Регистрация: 22.02.2021
Сообщений: 28
30.05.2021, 16:21  [ТС]
исправил как сказали, но пишет что неверный ответ, хотя все вернро

Добавлено через 1 минуту
отступы тут так скопировались

Добавлено через 1 час 11 минут
0
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
30.05.2021, 17:37
Alexander89,
Python
1
a = list(map(int,input().split()))
0
0 / 0 / 0
Регистрация: 22.02.2021
Сообщений: 28
30.05.2021, 20:50  [ТС]
Всем спасибо, решение нашел
0
29 / 27 / 2
Регистрация: 17.07.2019
Сообщений: 38
08.09.2022, 18:31
Вот решение если надо кому просто в алгоритм сортировки пузырьком надо добавить счётчик перестановок и вернуть его
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
def count_of_swaps_in_bubble_sort(a):
    n = len(a)
    unordered = True
    count_of_swaps = 0
    while unordered:
        unordered = False
        for j in range(n - 1):
            if a[j] > a[j + 1]:
                a[j], a[j + 1] = a[j + 1], a[j]
                count_of_swaps += 1
                unordered = True
        n -= 1
    return count_of_swaps
n = int(input())
a = list(map(int, input().split()))
print(count_of_swaps_in_bubble_sort(a))
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.09.2022, 18:31
Помогаю со студенческими работами здесь

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

Найти количество обменов пузырьковой сортировки
Подскажите пожалуйста , как найти количество обменов #include &lt;iostream&gt; using namespace std; int main() { int *arr; //...

Сколько проходов по списку выполнит алгоритм пузырьковой сортировки?
Дан список из 10 элементов: 8 1 7 4 3 9 2 5 6 10 Сколько проходов по списку выполнит указанный в лекции алгоритм пузырьковой...

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

Алгоритм пузырьковой сортировки
#include&lt;iostream.h&gt; #define SIZE 5 void bsort (int iArray, int n); int main() { char ch; int ii; int iArray ; for(ii =...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru