КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Шейкерная сортировка
Лекция 13 Begin Begin Begin While not EOF(F) do Begin Begin Var Begin Ifnot AloneItem(sName, Salary, pNew) then Begin Var Else End Begin Begin Begin Begin Implementation Public Protected Type Interface Begin Var Uses SysUtils, Unit1 in 'Unit1.pas', Unit2 in 'Unit2.pas', Unit3 in 'Unit3.pas';
MyList1: MyList1Class; MyList2: MyList2Class; MyList3: MyList3Class;
MyList1:= MyList1Class.Create; MyList1.AppendFromFile('c: List1.txt'); MyList1.ShowList; WriteLN;
MyList2:= MyList2Class.Create; MyList2.PrependFromFile('c: List2.txt'); MyList2.ShowList; WriteLN;
MyList3:= MyList3Class.Create; MyList3.InsertFromFile('c: List1.txt'); MyList3.ShowList; Readln; end. Текст файла Unit1.pas:
unit Unit1;
pPersonType = ^PersonType;
PersonType = record sName: string[40]; Salary: double; pNext: pPersonType; end;
MyList1Class = Class(TObject) pHead, pTail: pPersonType;
constructor Create; destructor Destroy;
function AloneItem(sName: string; Salary: double; var pNew: pPersonType): boolean;
procedure AppendItem(sName: string; Salary: double);
procedure AppendFromFile(sFileName: string);
procedure ShowList; end;
constructor MyList1Class.Create; pHead:= Nil; pTail:= Nil; end;
destructor MyList1Class.Destroy; // Код будет написан позже! end;
function MyList1Class.AloneItem(sName: string; Salary: double; var pNew: pPersonType): boolean; New(pNew); if pNew = Nil then Halt; // Нет места в памяти – прекращаем работу.
pNew^.sName:= sName; pNew^.Salary:= Salary; pNew^.pNext:= Nil;
if pHead = Nil then pHead:= pNew; pTail:= pNew; AloneItem:= True; AloneItem:= False; end; procedure MyList1Class.AppendItem(sName: string; Salary: double); pNew: pPersonType; pTail^.pNext:= pNew; pTail:= pNew; end; end;
procedur e MyList1Class.AppendFromFile(sFileName: string); F: Text; sName: string[40]; Salary: double;
Assign(F, sFileName);
{$I-} Reset(F); {$I+}
if IOResult <> 0 then WriteLN('File ', sFileName, ' not found'); Halt; end;
Readln(F, sName); Readln(F, Salary);
AppendItem(sName, Salary); end; end;
procedure MyList1Class.ShowList; pCurr:= pHead;
Writeln('Name':40, ' ', 'Salary'); Writeln('----':40, ' ', '------');
while pCurr <> Nil do Writeln(pCurr^.sName:40, ' ', pCurr^.Salary:8:2); pCurr:= pCurr^.pNext; end; end;
end.
Сортировка массивов (продолжение)
Данная сортировка есть улучшенный вариант сортировки методом пузырька. На первом полу шаге проверяются (справа налево) все пары соседних элементов массива, начиная с последней. Если пара «неправильная» (левый элемент больше правого), производится обмен значениями в паре. Наименьший из всех элементов массива, если только он не стоял на первом месте, «просочится» в результате первого шага на первую позицию, поскольку он будет «неправильно» расположен относительно каждого из своих соседей слева. Вместе с тем, может оказаться и так, что первый элемент изначально был минимальным. Более того, может оказаться так, что первые k элементов изначально занимали подобающие им места, поскольку были наименьшими и стояли в порядке возрастания. Признаком такой ситуации может послужить то, что первые k элементов не участвовали в обмене. Следовательно, последующая сортировка должна затронуть только элементы массива с номерами большими, чем k. Переменная L (после изменения оператором L:=k+1) имеет смысл левой границы неотсортированной пока части массива. На втором полу шаге проверяются (теперь слева направо) все пары соседних элементов массива, начиная с (L-1)–ой. Если последние k элементов изначально занимали подобающие им места, поскольку были наибольшими и стояли в порядке возрастания, переменная R (после изменения оператором R:=k-1) будет содержать информацию о правой границе неотсортированной пока части массива. На втором и последующем шагах продолжают сближаться левая и правая границы неотсортированной части массива. Когда они «схлестнутся», сортировка заканчивается. Шейкерная сортировка, увы, работает несколько хуже сортировки методом прямого выбора. procedure ShakerSort;
Дата добавления: 2014-01-04; Просмотров: 303; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |