1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
| Анна |
5.12.2005 14:54
Сообщение
#1
|
![]() Бывалая ![]() ![]() ![]() Группа: Пользователи Сообщений: 290 Пол: Женский Реальное имя: Анютка Репутация: 7 |
Создать компонентный файл реализующий базу данных "записная книжка", которая состоит из след. полей: имя, фамилия, отчество, дата рождения, город, улица, дом, квартира, телефон.
Программа должна обеспечивать вввод записи с клавиатуры, а также сортировки записи по полю (отсортированную базу сохранить в другом файле) Сортировка по фамилии. Вот что получилось: Program Lab11; Не получается отсортировать, да и мне кажется, что моя программа слишком громоздкая |
![]() ![]() |
| Анна |
11.12.2005 15:43
Сообщение
#2
|
![]() Бывалая ![]() ![]() ![]() Группа: Пользователи Сообщений: 290 Пол: Женский Реальное имя: Анютка Репутация: 7 |
Небольшие изменения:
Немного запуталась в программе... Код Program Lab11; uses crt; const max = 30; type base = record name, family, otchestvo, data, city, street: string[50]; dom, kv, tel: integer; end; List = array[1 .. max] of base; procedure ReadInfo(var r: base); begin write('Имя:'); readln(r.name); write('Фамилия:'); readln(r.family); write('Отчество:'); readln(r.otchestvo); write('Дата рождения:'); readln(r.data); write('Город:'); readln(r.city); write('Улица:'); readln(r.street); write('Дом:'); readln(r.dom); write('Квартира:'); readln(r.kv); write('Телефон:'); readln(r.tel); end; procedure WriteInfo(r: base); begin writeln('Имя: ' , r.name); writeln('Фамилия: ', r.family); writeln('Отчество: ', r.otchestvo); writeln('Дата рождения: ', r.data); writeln('Город: ', r.city); writeln('Улица: ', r.street); writeln('Дом: ', r.dom); writeln('Квартира: ', r.kv); writeln('Телефон: ', r.tel); end; {Если длина строки 1 больше длины 2 строки, то сдвигаем 1 строку вперёд на 1 ? и т.п.} function Compare (T1, T2: base): integer; begin if length (T1.family) > length (T2.family) then Compare := 1 else if length (T1.family) = length (T2.family) then Compare := 0 else Compare := -1 end; {А дальше я совсем запуталась ...} procedure QuickSort (var A: List; Lo, Hi: Integer); var i,j: integer; x, y: base; procedure Sort (l, r: Integer); begin repeat x := A[(l+r) shr 1]; i := l; j := r; repeat while Compare( A[i], x ) < 0 do inc(i); while Compare( A[j], x ) > 0 do dec(j); if i <= j then begin y := A[i]; A[i] := A[j]; A[j] := y; inc(i); dec(j); end; until i > j; if l < j then Sort (l, j); l := i; until l >= r; end; begin Sort (Lo,Hi); end; var mass: List; filename: string; f, rf: file of base; i, j, k, g:integer; key: char; proverka:boolean; begin clrscr; write('Введите имя исх файла: '); readln(filename); assign(f, filename); rewrite(f); write('Введите имя рез файла: '); readln(filename); assign(rf, filename); rewrite(rf); g := 0; repeat inc(g); ReadInfo(mass[g]); write(f, mass[g]); writeln('Выход ESC'); writeln('Для продолжения нажмите любую клавишу'); writeln; key := readkey; until key = #27; reset(f); i := 0; while not eof(f) do begin inc(i); read(f, mass[i]); end; {сортировка ...} QuickSort(mass, 1, i); { clrscr;} writeln('Отcортированные данные: '); for g := 1 to i do begin writeln; WriteInfo(mass[g]); write(rf, mass[g]); end; writeln; writeln('Нажмите любую кнопку!'); readln; close(rf); close(f); end. Сообщение отредактировано: Анна - 11.12.2005 15:45 |
Анна База Данных 5.12.2005 14:54
volvo
Здесь была?
FAQ: Как упорядочить данные по возрас... 5.12.2005 14:57
volvo Анна, смотри аттач :cool: 6.12.2005 1:03
Анна To: volvo
Спасибо!
Просто у самой пока време... 6.12.2005 15:49
Анна To: volvo
Выдаёт ошибку при открытии результирующ... 8.12.2005 20:57
volvo Анна, это - типизированный файл, а не текстовый...... 8.12.2005 22:34
Анна Я имела ввиду уже отсортированные данные :cool: . 9.12.2005 15:33
volvo Я тоже... Этот фрагмент идет после
QuickSort(mass,... 9.12.2005 15:58
Анна Всё, разобралась!
значит данные уже отсортиро... 9.12.2005 16:33
volvo Анна, не путай... ClrScr стоит ПЕРЕД выводом на эк... 9.12.2005 16:37
Анна To: volvo
Абсолютно ничего не исправляла. Попробу... 9.12.2005 20:06
volvo Анна,
погоди, а почему ты делаешь так:
{ Если длин... 12.12.2005 2:38
Анна volvo, ага, всё поняла ..
Вот мой метод сортировк... 12.12.2005 21:16
volvo {
Ну, это и есть реализация метода пузырька -
... 13.12.2005 0:07
Анна volvo, поставил в тупик. Но нам сказали делать пуз... 13.12.2005 15:43
volvo for i:=2 to g do
for j:=g downto i do
{ срав... 13.12.2005 15:54
Анна volvo, не поверишь, сама сейчас до этого догадалас... 13.12.2005 16:13
Анна ну что я могу сказать ...
да вот:
for i:=1 to g-1 ... 13.12.2005 16:52
Анна end;
reset(vf);
.......
close(rf);
end.
Как сде... 19.12.2005 20:18
Анна Нет никаких соображений? :wub: 24.12.2005 13:34
volvo WriteLn(mass[2].otchestvo);
В чем проблема? :blin... 24.12.2005 13:38![]() ![]() |
|
Текстовая версия | 8.12.2025 14:47 |