170 похожих чатов

Задача: Mетод пузырьковой сортировки, является неэффективным для больших массивов. Сделайте следующие

простые изменения для повыпения эффективности пузырьковой сортировки.


Данные в массиве могут уже находиться в надлежащем порядке или порядке, близком к нему, так зачем делать девять проходов, если будет достаточно менышего количества? Измените сортировку так, чтобы в конце каждого прохода проверялось. делались ли перестановки. Если перестановок не было, то данные уже находятея в нужном порядке, так что программа должна завершиться. Если перестановки были, то необходим по крайней мере еще один проход.

Моё решение:

void bubbleSortArray(int array[],int size){
int tmp=0;
int countForBreak=0;
for (int pass = 1; pass < size; pass++) {
if(countForBreak==size-1)
break;
else{
for (int i = 0; i < size-1; i++) {
if(array[i]>array[i+1]){
tmp=array[i];
array[i]=array[i+1];
array[i+1]=tmp;
}
else
countForBreak++;
}
}
}
}

2 ответов

10 просмотров

К чему сравнение с size-1? Нужен булевый флаг. Если на текущем проходе внешнего цикла не было перестановок, массив сортирован

Alexius-Bèlov Автор вопроса

это Си

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Карта сайта