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

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

30.05.2021, 14:26. Показов 5409. Ответов 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
8840 / 4492 / 1864
Регистрация: 27.03.2020
Сообщений: 7,312
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
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru