IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

 
 Ответить  Открыть новую тему 
> Метод алфавитной индексации
Sanya01078
сообщение 18.03.2010 14:52
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 10
Пол: Мужской

Репутация: -  0  +


Пожалуйста помогите решить задачку! М е т о д а л ф а в и т н о й и н д е к с а ц и и.
Данный алгоритм применяется для таблиц, содержащих алфавитно-
цифровую информацию, таких, как таблицы символических имен и литералов,
таблицы внешних имен и другие. Идея его заключается в том, что для
сортировки используется первый символ ключа. Строки результирующей
таблицы, начинающиеся с одной и той же буквы, будут объединены в группы.
Кроме результирующей таблицы создается массив входов, количество
элементов которого определяется количеством символов в алфавите. Каждый
элемент массива сопоставляется конкретному символу алфавита, и будет
содержать указатель на номер первой строки группы строк, начинающихся с
данного символа. Если учесть, что символы в алфавите упорядочены, то
преобразование кода символа в номер элемента массива входов выполняется
достаточно просто. Например, если используются только заглавные буквы
латинского алфавита, то количество элементов будет равно 26. Тогда первый
элемент массива будет соответствовать букве A, а последний - букве Z. Для
преобразования можно воспользоваться формулой:
i=ord(CH)-ord('A')+1,
где CH - символ алфавита;
i - номер элемента массива входов;
ord()- функция преобразования символьного формата в числовой.
Сортировка выполняется за один проход исходной таблицы и
складывается из следующих шагов:
- в ключе поиска выделить первый символ и преобразовать его код
в номер элемента массива входов;
- если элемент массива входов пуст(=0), то занести в него
значение указателя на свободную строку в результирующей таблице;
указатель нарастить; а в результирующую строку перенести строку из
исходной таблицы; после чего перейти к следующей строке исходной таблицы;
- если элемент массива входов занят(<>0), то:
1) в результирующей таблице выполнить физическое перемещение
строк на одну позицию, начиная со строки, на которую указывает элемент
массива входов (пусть j), в направлении к концу таблицы;
2) в массиве входов все элементы, значения которых больше j,
нарастить на 1;
3) обрабатываемую строку исходной таблицы перенести в
освободившуюся строку j результирующей таблицы;
4) перейти к следующей строке исходной таблицы.
Алгоритмы поиска наиболее часто используются в системных
программах, и от их эффективности во многом зависит эффективность работы
системной программы. Все алгоритмы поиска можно разделить на 2
класса: алгоритмы, работающие с неупорядоченной и только с упорядоченной
таблицей. К первому классу могут быть отнесены алгоритмы линейного и
случайного поиска. Ко второму - алгоритмы двоичного, вычислением адреса
и с алфавитной индексацией.
Не как не пойму как это выполнить!
Если есть какие то идеи напишите пожалуйста!!
Отсортировать надо массив строк. В строке должно быть по 3-и символа!

Сообщение отредактировано: Sanya01078 - 18.03.2010 14:53
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 20.07.2025 18:12
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"