База даних по приватним підприємствам регіону

Міністерство внутрішніх справ України

Харківський національний університет внутрішніх справ

Навчально-науковий інститут менеджменту, соціальних та інформаційних технологій

Кафедра інформаційних систем і технологій в діяльності ОВС

Курсова робота

з дисципліни «Основи програмування та алгоритмічні мови»

на тему: «База даних по приватним підприємствам регіону»

Харків р.

Зміст

Вступ

1. Основна частина

1.1 Неформальна постановка задачі

1.2 Формальна постановка задачі

1.3 Структура зберігаючих даних

2. Алгоритми

2.1 Алгоритм основної програми

3. Вихідний код програми

Висновок

Список використаної літератури

Вступ

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

Я вибрав мову програмування Turbo Pascal, з метою закріплення своїх навиків з програмування.

1. Основна частина

1.1 Неформальна постановка задачі

Розробити програму «Приватка» для збереження та перегляду всієї інформації що приватних підприємств.

    Введення і збереження в файл:

      Назва підприємства

      Адреса підприємства

      Власник підприємства;

    Можливість редагування даної бази

    Організація пошуку за критеріями:

      Назва підприємства

      Адреса підприємства

      Власник підприємства;

    Можливість перегляду всіх існуючих документів

      Перегляд скороченого варіанту бази

      Перегляд повного варіанту даних, які занесені до бази

    Можливість видалення всієї бази.

    Зручний інтерфейс для користувача

    Швидкість та простота роботи в даній програмі

1.2 Формальна постановка задачі

Вихідні дані:

Нехай B={B>1>,B>2>,…,B>i>}, де ( i=1, 2, ..., N ) – множина підприємств.

R>i >є B>i >– ПІБ власника приватного підприємства

D>i >є B>i >– адреса підприємства

O>i >є B>i> – назва підприємства

Таким чином отримуємо нову сукупність B>ij >– яка більш розширена в плані інформації про підприємства

Результат:

Множина K>j>, яка формуються з вхідних даних а саме множини B>ij.>

Математична модель:

Таким чином множина K>j >є підмножиною B>ij>

1.3 Структура зберігаючих даних

P – Запис для занесення в нього інформації а потім до файлу і навпаки

    Na – поле для назви підприємства

    Re – поле для адреси

    Vl – поле для ПІБ власника

Pamka – малює рамку

Voz – відповідае за введення та збереження інформації

Viv – пошук в базі даних

Dal – для видалення

Newreadkey – розширений код клавіши

Rrr – допоміжна для рамки

Prig – меню програми

2. Алгоритми

2.1 Алгоритм основної програми




Перехід по пунктам меню

3. Вихідний код програми

uses crt ,dos;

type p=record

na,re,

string[15];

end;

var f: file of p;pr:p;

st1,st2,st3,st4:string;

e:char;d,pu:byte;

{--------------}

procedure pamka (x1,y1,x2,y2:integer);

var i,c:integer;

begin

textcolor(1);

gotoxy(x1,y1);

write(#201);

for i:=1 to x2-x1-1 do

begin

gotoxy(x1+i,y1);

write(#205);

end;

gotoxy(x2,y1);

write(#187);

for i:=1 to y2-y1-1 do

begin

gotoxy(x2,y1+i);

write(#186);

end;

gotoxy(x2,y2);

write(#188);

for i:=1 to x2-x1-1 do

begin

gotoxy(x2-i,y2);

write(#205);

end;

gotoxy(x1,y2);

write(#200);

for i:=1 to y2-y1-1 do

begin

gotoxy(x1,y1+i);

write(#186);

end;

end;

{.........................}

procedure voz;

var i,n:integer;

begin

window(1,1,40,25);

textbackground(3);

clrscr;

pamka(1,23,39,25);

gotoxy(13,24);

write('ZAPOLNENIE');

window(4,1,37,22);

write('Vvedi kol-vo predpreyatiy- ');readln(n);

assign(f,'D:\reg');

rewrite(f);

for i:=1 to n do

begin

clrscr;

seek(f,filesize(f));

writeln('Predpreyatie#',i);

write('Vvedi nas.predpreyatia- ');readln(pr.na);

write('Vvedi reg. v kotor. rasp. predpr-');readln(pr.re);

write('Vvedi vladelca predpr.- ');readln(pr.vl);

write(f,pr);

end;

close(f);

end;

{...................}

procedure viv;

var i:integer;

begin

window(1,1,40,25);

textbackground(3);

clrscr;

pamka(1,23,39,25);

gotoxy(13,24);

write('prosmotr');

window(4,1,37,22);

if fsearch('reg','d:\')='' then

begin

textcolor(132);

writeln('FAIL Ne NAYDEN');

end

else

begin

assign(f,'d:\reg');

reset(f);

for i:=0 to filesize(f)-1 do

begin

seek(f,i); read(f,pr);

writeln('nasv. predpr.- ',pr.na);

writeln('region raspol.- ',pr.re);

writeln('Vladeletc- ',pr.vl);

writeln;

end;

close(f);

end;

readln;

end;

{.................}

procedure dal;

begin

window(1,1,40,25);

textbackground(3);

clrscr;

pamka(1,23,39,25);

gotoxy(13,24);

write('UDALENIE');

window(4,1,37,22);

if fsearch('reg','d:\')='' then

begin

textcolor(132);

writeln('FAIL Ne NAYDEN');

end

else

begin

Writeln('Fail udalen ');

assign(f,'d:\reg');

erase(f);

end;

end;

{-------------------}

procedure kl (x1,y1,x2,y2,a,b:byte);

var i:integer;

begin

textbackground(a);

textcolor(b);

window (x1,y1,x2,y2);

write('Й');

for i:=1 to (x2-x1)-1 do

begin

write('Н');

end;

write('»');

for i:=2 to (y2-y1)-1 do

begin

gotoxy(1,i);

write('є');

gotoxy(x2-x1+1,i);

write('є');

end;

write('И');

for i:=1 to (x2-x1)-1 do

begin

write('Н');

end;

write('ј');

end;

{------------------------}

procedure newreadkey (var a:char;var b:byte);

begin

b:=0;

a:=readkey;

if a=#0 then

b:=ord(readkey);

end;

{------------------}

procedure rrr(st1,st2,st3,st4:string);

begin

window(1,1,40,25);

textbackground(7);

clrscr;

kl(5,2,35,5,7,0);

gotoxy(3,1);

write (#181,st1,#198);

kl(5,8,35,11,7,0);

gotoxy(3,1);

write (#181,st2,#198);

kl(5,14,35,17,7,0);

gotoxy(3,1);

write (#181,st3,#198);

kl(5,20,35,23,7,0);

gotoxy(3,1);

write (#181,st4,#198);

end;

{------------------}

procedure prig(x,y,u,n:byte);

var i:byte;

begin

textbackground(0);

textcolor(u);

gotoxy(x,y);

for i:=1 to n do

write(#176);

end;

{==================}

begin

window(1,1,40,25);

textbackground(7);

clrscr;

st1:='Udalenie';

st2:='Predpreyatie';

st3:='Prosmotr';

st4:='Vihod';

rrr(st1,st2,st3,st4);

window(1,1,40,25);

prig(6,3,14,29);

pu:=1;

repeat

newreadkey(e,d);

if d=80 then

pu:=pu+1;

if d=72 then

pu:=pu-1;

if pu=5 then

pu:=1;

if pu=0 then

pu:=4;

case pu of

1: begin

if e=#13 then

dal;

rrr(st1,st2,st3,st4);

window (1,1,40,25);

prig(6,3,14,29);

end;

2: begin

if e=#13 then

voz;

rrr(st1,st2,st3,st4);

window (1,1,40,25);

prig(6,9,14,29);

end;

3: begin

if e=#13 then

viv;

rrr(st1,st2,st3,st4);

window (1,1,40,25);

prig(6,15,14,29);

end;

4: begin

if e=#13 then

halt;

rrr(st1,st2,st3,st4);

window (1,1,40,25);

prig(6,21,14,29);

end;

end;

until e=#27;

end.

Висновок

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

Список використаної літератури

    Струков В.М. Основи алгоритмизации и програмирования. Часть 2. Учебное пособие. – Харьков: Изд. Нац. ун-та внутр.дел,2003. – 188 с.

    Сердюченко В.Я. Розробка алгоритмів та програмування на мові Turbo Pascal. – X.,1995.

    Немнюгин С.А. Turbo Pascal. – СПб.: Питер, 2002. – 496 с.: ил.