Сортировка Шелла! Рекомендую понять ее! Алгоритм прост и эффективен!
 

Содержание:

Я - профессиональный и опытный репетитор по информатике, программированию и математике

Вы ищите репетитора по информационным технологиям? Меня зовут Александр Георгиевич, и я тот, кто вам нужен! Уже на протяжении 10 лет я занимаюсь подготовкой школьников к успешной сдаче ОГЭ и ЕГЭ по информатике. Студентам оказываю поддержку в реализации всевозможных работ по программированию и помогаю им сдать различные экзамены по программированию.

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

В основном я занимаюсь информатикой и программированием, однако иногда происходит мультиподготовка, например, когда я готовлю 11-ника к успешной сдаче ЕГЭ, как по информатике, так и по математике. Не стоит забывать о том, что основу информатики кристаллизует математика, и данные дисциплины прекрасно дополняют друг друга.

Уверен в том, что на этой странице вы оказались не случайно! Вас интересует алгоритм сортировки Шелла. Только не нужно устраивать иеремиаду, когда после прочтения данной статьи вам не все будет понятно. Для фундаментального разбора алгоритма сортировки Шелла записывайтесь ко мне на первый пробный урок.

Сортировка Шелла – это, по сути, оптимальная модификация алгоритма сортировки вставками

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

Еще одним краеугольным камнем в алгоритме сортировки Шелла является выбор так называемого шага упорядочивания. Существует множество теоретических изысков по данной проблеме, и ученые вывели различные формульные зависимости, позволяющие максимально оптимально детерминировать шаг сортировки. Но в большинстве случаев все происходит достаточно тривиально: изначальный шаг составляет ровно половину длины заданного массива.

Также вы должны прекрасно уметь проводить такую информатическую операцию, как сдвиг элементов одномерного массива на одну позицию влево/вправо. Это несложное действие, при котором используется циклическая конструкция и некоторое количество клеток вашего головного мозга.

Мультимедийная презентация алгоритма сортировки Шелла

Выделив свободное время в своем плотном расписании уроков, я специально для вас снял видеоролик, в котором в наглядной, а главное - в доступной форме изложен алгоритм сортировки Шелла. Сразу предупреждаю, что в нем вы не найдете пример программного кода, там повествуется исключительно об алгоритмической составляющей этого способа сортировки.

Пример кода программы на языке Паскаль, реализующего алгоритм сортировки Шелла

Меня часто спрашивают мои ученики-неофиты: насколько сложно самостоятельно запрограммировать алгоритм сортировки Шелла, до какой степени трудно и долго изучать его на самом глубоком уровне, понять все его хитросплетения? Как правило, я отвечаю, что данный процесс достаточно длителен и интеллектуально затратен. Вам придется полностью вызубрить и понять фундаментальные основы программирования перед тем, как вы сможете реализовать данный алгоритм на практике, на каком-либо языке программирования.

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

  1. {заголовок программы}
  2. program shellSort;
  3. {раздел описания констант}
  4. const
  5. {количество элементов массива}
  6.   N = 10;
  7. {раздел объявления переменных}  
  8. var
  9. {сортируемый одномерный массив}
  10.   v: array[1..N] of integer;
  11. {шаг сортировки Шелла}  
  12.   d: integer;
  13. {вспомогательные переменные}
  14.   i, t: integer;
  15. {признак перестановки}  
  16.   k: boolean;
  17. {начало главного блока}  
  18. begin
  19. {чтобы каждый раз генерировались новые числа}
  20.   randomize;
  21. {заполнение массива случайными числами
  22.  от -100 до +100 и вывод на экран}  
  23.   write('ДО сортировки:    ');
  24.   for i := 1 to N do
  25.   begin
  26.     v[i] := -100 + random(201);
  27.     write(v[i]:6);
  28.   end;
  29. {шаг сортировки изначально равен
  30.  половине длины исходного массива}  
  31.   d := N div 2;
  32. {пока массив неотсортирован}  
  33.   while(d > 0) do
  34.   begin
  35.     k := true;
  36. {пока есть перестановки}    
  37.     while k do
  38.     begin
  39.       k := false;
  40.       i := 1;
  41.       for i := 1 to N - d do
  42.       begin
  43. {сравнение элементов на интервале d}      
  44.         if(v[i] > v[i + d]) then
  45.         begin
  46.           t := v[i];
  47.           v[i] := v[i + d];
  48.           v[i + d] := t;
  49.           k := true;
  50.         end;
  51.       end;
  52.     end;
  53. {сокращаем шаг сортировки в 2 раза}    
  54.     d := d div 2;
  55.   end;
  56. {печатаем отсортированный массив на экран}  
  57.   writeln;
  58.   write('ПОСЛЕ сортировки: ');
  59.   for i := 1 to N do
  60.     write(v[i]:6);
  61.   writeln;
  62. end.

Если остались какие-то вопросы, неуверенность, недопонимание, то...

Если, прочитав данный информационный материал, у вас появились какие-то дополнительные вопросы относительно алгоритма сортировки Шелла или вы хотите познакомиться с другими, не менее интересными способами упорядочивания данных, то берите в руки мобильный телефон и звоните мне на контактный номер. Задавайте любые ваши тематические вопросы, договаривайтесь о проведении первого индивидуального занятия.

Наверняка у вас проскользнула мысль о цене: сколько же стоят мои услуги? Своим потенциальным ученикам я предлагаю 144 варианта взаимовыгодного сотрудничества. Даже самый-самый требовательный клиент сможет выбрать такое взаимодействие, которое полностью удовлетворит его запросы.

Меня часто спрашивают, провожу ли я занятия на выезде. Мой ответ утвердительный – да! Своим клиентам я предлагаю четыре разных территориальных формата взаимодействия:

Не откладывайте свое решение в долгий ящик. Звоните прямо сейчас и записывайтесь на индивидуальные уроки по информатике, математике и программированию. Скажу вам честно, я – достаточно востребованный русскоязычный репетитор, следовательно, я не могу взять всех желающих под свое «крыло». Количество ученических мест ограниченно в любое время года, в особенности весной.

Отзывы
моих учеников

Коваленко
Всеволод

 
Хочу отметить дисциплину на уроках, я чувствовал себя как на официальной паре, никаких шуток и панибратств. Очень понравилось серьезное отношение к дисциплине, т к я сам челвоек дисциплинированный. Спасибо вам!

Корелов
Дмитрий

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

Крылов
Антон

 
Я не ожидал, что получу 83 балла, думал, максимум 70, а результат меня ошеломил. Вы просто мастер Александр Георгиевич, выражаю вам благодарность большую.

Иванов
Денис

 
Очень много нового узнал о ДС, Александр Георгиевич показал несколько способов построения бинарного дерева, а также реализацию функций повышенного уровня сложности. Когда шел на экзамен, то абсолютно не волновался, так...

Волков
Павел

 
Спасибо вам большое. Да, курсовая была непростой, но я сдал ее на 5-ку. Хочу отметить атмосферу проводимых уроков: во-первых, мы занимались в чистой и опрятной комнате, во-вторых, на уроке стоит здоровая учебная...

Минаев
Сергей

 
Выражаю благодарность за добросовестную подготовку к успешной сдаче ЕГЭ по информатике и ИКТ. Особенно хочется отметить подход репетитора к работе, видно, что ему тоже интересно совместно со мной решать эти задачи, он...

Каховская
Оксана

 
Хочу всем сказать, что я по своему духу лингвист. Паскаль - это формальный язык написания текстов. Благодаря репетитору я уверенно себя стала чувствовать при написании программ. Мне досконально понятны все базовые...

Богдан
Игнатьев

 
Теперь я чувствую себя уверенно при программировании графических примитивов. Я еще раз убедился, что хороший учитель очень важен для хорошего обучения. В следующем учебном году у нас будет дисциплина "Мультипликация и...

Ланцев
Дмитрий

 
Я был очень круто подготовлен. Александр Георгиевич натаскивал меня по полной программе, мы прорерашли более 200 задач по программированию, научились строить выйгрышные стратегии. Я сам виноват, что не повторил...

Агаров
Ярослав

 
Вы мой любимый репетитор) Я с вами занимаюсь программированием уже на протяжении двух лет и дальше планирую, т к у нас дальше начинается объектный Паскаль, т е Дельфи. Спасибо вам большое, на ваших частных уроках всегда...

Булычев
Владимир

 
С учителем мы сошлись характерами и я стал заниматься регулярно и продолжительное время. Очень много давалось домашних заданий, что я даже не успевал все выполнять, так как был занят еще в ВУЗе. Выражаю огромную...
Смотреть все отзывы
 
 
 
 
 
 
Авторизация на сайте
 
 
 
Обнаружили
ошибку на сайте?
Занятия по информатике