0 / 0 / 0
Регистрация: 13.04.2012
Сообщений: 16
1

Работа с файлами прямого доступа. Хешированные фай-лы

30.11.2010, 00:52. Показов 3545. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Вот недавно перешли на С и препод такуб задачку подкинул , который день голову ломаю...
Необходимо разработать и отладить программу на Си, реализующую методы для работы с файлами прямого доступа.
Для распределения записей в файле используется хеширование на ос-нове функции середины квадрата. Размер таблицы изменяется: 16,32,64 и так далее записей.
Для преодоления коллизий записи в сегменте организуются в виде связанного списка: то есть запись в основной области является заголовком списка записей в области переполнения, куда попадают все записи, всту-пающие в коллизию.
Если число записей начинает превышать число сегментов в 2 раза, то создается новый файл вдвое большего размера, и в него переписываются записи из старого файла с использованием новой функции размещения (количество разрядов в "середине квадрата" увеличивается на 1).

C++
1
2
3
4
5
6
7
8
9
10
11
// Функция рассеивания для файла из 1024 записей и 16 разрядного ключа
int h(unsigned key) {
   unsigned long n, n1;
   int m;
   n = (unsigned long)key * key;
   // Подсчет количества значащих битов в n 
   for (m=0, n1 = n; n1 !=0; m++, n1 >>= 1);
   if (m < 10) return(n); 
   m = (m - 10) / 2; // m - количество битов по краям
   return((n >> m) & 0x3FF);
}
Листинг 1. Пример хеш-функции для целочисленных ключей

Программа должна содержать следующие функции:
• открытие файла file_t openfile(char *name);
• создание файла file_t createfile(char *name);
• закрытие файла int closefile(file_t f);
• поиск записи по ключу int searchrec(file_t f, key_t key);
• добавление новой записи int appendrec(file_t f, data_t data);
• изменение существующей записи updaterec(file_t f, key_t key, data_t newdata);
• удаление записи по ключу deleterec(file_t f, key_t key);
• и другие функции по вашему усмотрению.

Функции должны иметь возможность работы с несколькими файлами одновременно. В случае ошибочных ситуаций устанавливать и проверять глобальную переменную errcode.

Для проверки работоспособности разработанной функции создать тестирующую функцию, в которой необходимо предусмотреть ввод исходных данных с клавиатуры, вывод на печать результатов. Проверить все режимы работы функций и возможность работы с несколькими фай-лами.
Оценить быстродействие операций вставки, удаления записей с ис-пользованием СИНХРОНИЗИРОВАННОГО и обычного режимов работы с файлами.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
30.11.2010, 00:52
Ответы с готовыми решениями:

Работа с файлами (считать очередь, вывести на экран, дополнить ее элементами и перезаписать в фай)
Есть очередь, записаная в файле. Нужно считать ее, вывести на екран, дополнить ее елементами и...

Работа с файлами последовательного доступа
Один из пунктов меню программы позволяет текст, вводимый пользователем с клавиатуры, преобразовать...

Нарушения прав доступа к чтению (работа с файлами)
Пробую реализовать запись в файл: #define _CRT_SECURE_NO_WARNINGS #include &lt;iostream&gt; #include...

работа с файлами прямого доступа
Проблема с файлами прямого доступа. С самом файле должен быть бред в виде каких-то символов...

0
30.11.2010, 00:52
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.11.2010, 00:52
Помогаю со студенческими работами здесь

Работа с модулями и файлами прямого доступа
Привет! Люди добрые, помогите пожалуйста нарисовать блок-схему для отдельной процедуры, входящей...

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

работа с файлами последовательного доступа
Записать в файл последовательного доступа N действительных чисел. Вычислить сумму всех чисел в...

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

Новые блоги и статьи
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
Полезные поделки на Arduino, которые можно сделать самому
raxper 06.01.2025
Arduino как платформа для творчества Arduino представляет собой удивительную платформу для технического творчества, которая открывает безграничные возможности для создания уникальных проектов. Эта. . .
Подборка решений задач на Python
IT_Exp 06.01.2025
Целью данной подборки является предоставление возможности ознакомиться с различными задачами и их решениями на Python, что может быть полезно как для начинающих, так и для опытных программистов. . . .
С чего начать программировать микроконтроллер­­ы
raxper 06.01.2025
Введение в мир микроконтроллеров Микроконтроллеры стали неотъемлемой частью современного мира, окружая нас повсюду: от простых бытовых приборов до сложных промышленных систем. Эти маленькие. . .
Из чего собрать игровой компьютер
inter-admin 06.01.2025
Сборка игрового компьютера требует особого внимания к выбору комплектующих и их совместимости. Правильно собранный игровой ПК не только обеспечивает комфортный геймплей в современных играх, но и. . .
Обновление сайта www.historian.b­y
Reglage 05.01.2025
Обещал подвести итоги 2024 года для сайта. Однако начну с того, что изменилось за неделю. Добавил краткий урок по последовательности действий при анализе вредоносных файлов и значительно улучшил урок. . .
Как использовать GraphQL в C# с HotChocolate
Programming 05.01.2025
GraphQL — это современный подход к разработке API, который позволяет клиентам запрашивать только те данные, которые им необходимы. Это делает взаимодействие с API более гибким и эффективным по. . .
Модель полного двоичного сумматора с помощью логических операций (python)
AlexSky-coder 04.01.2025
def binSum(x:list, y:list): s=^y] p=x and y for i in range(1,len(x)): s. append((x^y)^p) p=(x and y)or(p and (x or y)) return s x=list() y=list()
Это мы не проходили, это нам не задавали...(аси­­­­­­­­­­­­­­­­­­­­­­­­­­х­р­о­н­­н­­­ы­­й счётчик с управляющим сигналом зад
Hrethgir 04.01.2025
Асинхронный счётчик на сумматорах (шестиразрядный по числу диодов на плате, но наверное разрядов будет больше - восемь или шестнадцать, а диоды на старшие), так как триггеры прошли тестирование и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru