Программисту нужно было реализовать структуру на версии языка FORTRAN
Программисту нужно было реализовать структуру на версии языка FORTRAN, в которой не поддерживались указатели и структуры. Поэтому мы использовали массив из 201 элемента для представления столбцов и два параллельных массива по 2000 элементов для представления точек. На рис. 10.3 изображены эти три массива, причем стрелки указывают на те элементы, индексы которых хранятся в нижнем массиве. Нумерация элементов массивов в языке FORTRAN начинается с единицы, а не с нуля, поэтому изображение на рисунке немного не соответствует тому, что в действительности было сделано в программе.
pointnum 17 53 В 1053 98 15 1800 437 832
row 2 5 126 1 138 11 111 67
firstincoi
0 3 5 5 1998 2000
0 1 2 3 199 200
Рис. 10.3. Индексация с помощью массивов
Точки в столбце i находятся в массивах row и pointnum между позициями firstincol[i] и firstincol[i+l]-l. Хотя столбцов всего 200, нам приходится определять элемент firstincol[200], чтобы это условие выполнялось всегда. Для обращения к точке с координатами (i, j) используется следующий код:
for k = [firstincol[i]. firstincoi[i+l]) if row[k] == j
return pointnum[k] return -1
Эта версия программы использует два массива по 2000 элементов и одни с 201 элементом. Программист реализовал эту схему именно так, как она здесь описана, используя 16-разрядные целые числа, и она заняла 8402 байта памяти. Программа работает несколько более медленно, чем в исходном варианте, поскольку в среднем для обращения к точке требовалось 10 обращений к элементам массивов. Однако ее производительности вполне хватало пользователям. Благодаря хорошей модульной структуре системы в целом нам удалось внести изменения за несколько часов, изменив лишь несколько функций. Производительность программы не ухудшилась, а нам удалось освободить 70 Кбайт памяти, которых нам так пе хватало.
Если бы нам показалось, что структура все равно занимает слишком много места, мы бы могли еще более уменьшить ее в объеме. Поскольку значения элементов массива row не превышают 200, их можно хранить в 1-байтовых беззнаковых целых (char). Это уменьшает занимаемый объем памяти до 6400 байт. Можно и вовсе избавиться от массива row, помещая соответствующую координату точки в ее запись:
for k = [f 1 гst 1 ncol [i ] . firstmcol [i+l]) if pen nt[pointnum[k]] row == j return pointnum[k]
return -1
Это уменьшает занимаемый объем до 4400 байт.
Опубликовал vovan666
April 17 2013 00:01:39 ·
0 Комментариев ·
4368 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.