У нас: 141825 рефератів
Щойно додані Реферати Тор 100
Скористайтеся пошуком, наприклад Реферат        Грубий пошук Точний пошук
Вхід в абонемент


}

fclose(out);

return 0;

}

int read_from_file(char *filename)

{

FILE *in;

int i;

if ((in = fopen(filename, "r"))

== NULL)

{

printf("Cannot open file '%s'.\n",filename);

return 1;

}

records=0;

rob=first;

while(!feof(in))

{

fscanf(in,"%i %16s %16s %i %i\n",

&i,rob->sName,rob->sCountry,&rob->iCount,&rob->iSum) records++;

if (rob->next==NULL) {

rob->next= new stItem;

rob=rob->next;

rob->next=NULL;

} else {

rob=rob->next;

}

}

rob->next=NULL;

fclose(in);

return 0;

}

void main (void)

{

char c;

//create an empty list

records=0;

first = new stItem;

rob=first;

rob->next=NULL;

//read saved database

read_from_file("EX");

//create backup copy

save_to_file("EX.BAK");

do{

//show menu

clrscr();

printf("[ESC] - Вихiд\n");

printf("[ 1 ] - Додaти запис\n");

printf("[ 2 ] - Вилучити запис\n");

printf("[ 3 ] - Показати записи\n");

printf("[ 4 ] - Вiдмiнити останню дiю\n");

printf("------------------------\n");

printf("В базi записiв: %i\n\n",records);

showmatch();

c=getch();

switch (c)

{

case '1': {

save_to_file("EX.BAK"); //create a backup copy

addrecord();

save_to_file("EX");

break;

}

case '2': {

save_to_file("EX.BAK"); //create a backup copy

deleterecord();

save_to_file("EX");

break;

}

case '3': {

showrecords();

break;

}

case '4': {

//restore from backup

read_from_file("EX.BAK");

save_to_file("EX");

break;

}

}

}while(c!=0x1B);

}

Вміст файлу “ЕХ”

1 Конфети Україна 12 1200

2 Борошно Болгарiя 120 12000

3 Аспiрин Нiмеччина 123 3458

4 АН-174 Україна 1 120000

5 Голка Туреччина 7 7

6 Ел.Двигун Китай 9 9000

7 Газонокосилка Албанiя 2 20000

Вміст файлу “ЕХР”

1 Конфети Україна 12 1200

2 Борошно Болгарiя 120 12000

3 Аспiрин Нiмеччина 123 3458

Сума = 16658

3.Опис програми

Для зберігання даних в пам’яті ми використали зв’язаний список, кожен елемент якого містить інформацію про поля, а також вказівник на наступний елемент списку, або ж значення NULL, якщо запис являється останнім в списку. Список є однонаправленим, номера записів не зберігаються в структурі а вираховуються, вказівник на перший елемент списку зберігається в глобальній змінній first.

Програма складається з наступних функцій:

main() – головна функція, очищає екран, створює порожній список, зчитує дані з файлу, виводить меню і дає можливість користувачу обрати необхідну операцію. Вихід з програми відбувається по натисненню клавіші <ESC>

addrecord() – додає в кінець списку новий запис, використовуючи введені користувачем дані

deleterecord() – запитує в користувача номер запису, та у випадку вірного вводу вилучає запис з введеним номером

showrecords() – виводить на екран поточний стан бази даних

showmatch() – шукає в списку елементи що задовільняють заданій умові і виводить цю інформацію на екран та в файл

save_to_file() – записує дані з пам’яті в файл, ім’я якого передається як параметр. Якщо файла з таким іменем не існує, він створюється, якщо існує – перезаписується.

read_from_file() – зчитує дані з файла в список.

Висновки

В даній курсовій роботі розроблено програму для роботи з відомостями про експорт товарів. Для зберігання даних в пам’яті використано списки, оскільки з даними, що зберігаються таким чином, зручно проводити операції вилучання, а також це не накладає на програму жорстких обмежень по максимальній кількості даних, що можуть оброблятись.

Програма має меню, за допомогою якого здійснюється вибір необхідної операції. Передбачено наступні режими роботи: «ввід нових даних», «вилучення», «перегляд» та «відміна останньої операції». Нові дані додаються в кінець списку. В режимі вилучення програма спитає номер запису, що необхідно вилучити. Для забезпечення можливості відновлення попереднього стану, перед кожною зміною списку, його стан фіксується в резервному файлі, звідки цю інформацію можна відновити в разі необхідності.

Інформація про кількість записів в базі даних, та про необхідні види експортних товарів виводиться під головним меню і оновлюється автоматично, під час будь-яких операцій з даними.

Перелік використаних літературних джерел

Глушаков С.В., Коваль А.В., Смирнов С.В. Язык программирования С++. – Харьков: Фолио, 2002. – 500 с.

Г. Шилдт. Самоучитель C++: Пер. с англ. - Санкт-Петербург: BHV-Санкт-Петербург, 1998. 620с.

К. Джамса. Учимся программировать на языке C++: Пер. с англ. - Москва: Мир, 1997. 320с.

ДОДАТКИ

Додаток А

Головне меню з відображення результатів

Режим вводу даних

Режим вилучення запису

Режим перегляду


Сторінки: 1 2