База даних по обліку вогнепальної зброї

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

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

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

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

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

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

на тему: «База даних по обліку вогнепальної зброї»

Харків р.

Зміст

Вступ

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

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

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

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

2. Алгоритми

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

2.2 Алгоритм процедури Zap

2.3 Алгоритм процедури Udal

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

Висновок

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

Вступ

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

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

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

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

Розробити програму « облік вогнепальної зброї» бля більш простої та оптимальної обробки інформації по зброї.

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

      Модель зброї;

      Калібр вогнепальної зброї;

      Вага зброї;

      Довжина зброї;

      Реєстраційний номер зброї;

      Висота зброї.

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

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

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

      Модель зброї;

      Калібр вогнепальної зброї;

      Вага зброї;

      Довжина зброї;

      Реєстраційний номер зброї;

      Висота зброї.

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

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

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

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

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

Нехай А множина всієї вогнепальної зброї. Тоді

А={А>1>, А>2>,…,А>} і=1..n. А> – певний вид зброї

А> = {Р>1>, Р>2>,…,Р>j>}

де Р>j >– певна характеристика даної зброї.

Множина Р>i>, яка формуються з вхідних даних а саме множини А>i>. під дією певного критерію:

К>1> – критерій Модель зброї

К>2> – критерій Калібр вогнепальної зброї

К>3> – критерій Вага зброї

К>4> – критерій Довжина зброї

К>5> – критерій Реєстраційний номер зброї

К>6> – критерій Висота зброї

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

А> = { А>1>, А>2>,…,А> }, де А> є σ>(А) вибірка

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

te – тип запис для занесення даних про автомобілі

    kal – перемінні строкового типу для зберігання калібоу

    ves – перемінні строкового типу для зберігання ваги

    dl – перемінні строкового типу для зберігання довжини

    vis – перемінні строкового типу для зберігання висоти

    med – перемінні строкового типу для зберігання моделі

    pr_nom – перемінні строкового типу для зберігання реєстраційного номеру

polo - процедура для малювання рамочки

menu - процедура для управління та виведення меню програми

strelka - процедура для пунктів меню

zap - процедура для занесення та збереження даних

udal – процедура для видалення всієї бази

poisk - процедура для пошуку за певними критеріями

prosm - процедура для виведення всіх відомостей які містяться в базі

2. Алгоритми

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
















2.2 Алгоритм процедури Zap

0100090000032a0200000200a20100000000a201000026060f003a03574d464301000000000001009a7c0000000001000000180300000000000018030000010000006c0000000000000000000000350000006f000000000000000000000091170000b903000020454d46000001001803000012000000020000000000000000000000000000007f120000771a0000c80000001f010000000000000000000000000000000f030058600400160000000c000000180000000a000000100000000000000000000000090000001000000091050000e1000000250000000c0000000e000080250000000c0000000e000080120000000c00000001000000520000007001000001000000a4ffffff00000000000000000000000090010000000000cc04400022430061006c0069006200720069000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000022003097220010000000949a220014982200e450f163949a22008c97220010000000fc982200789a22008a4ff163949a22008c9722002000000080e0b4618c972200949a220020000000ffffffff2c281502fbe0b461ffffffffffff0180ffff01807fff0180ffffffff0030000000080000000800002028720501000000000000005802000025000000372e9001cc00020f0502020204030204ff0200e1ffac004009000000000000009f01000000000000430061006c0069006200720000000000f000ba7654982200334eb661282e9362b49b2200c0972200d532ae612000000001000000fc972200fc9722000076ac6120000000249822002c2815026476000800000000250000000c00000001000000250000000c00000001000000250000000c00000001000000180000000c0000000000000254000000540000000000000000000000350000006f00000001000000e7298740a48e87400000000057000000010000004c00000004000000000000000000000091050000e100000050000000200057003600000046000000280000001c0000004744494302000000ffffffffffffffff92050000e2000000000000004600000014000000080000004744494303000000250000000c0000000e000080250000000c0000000e0000800e000000140000000000000010000000140000000400000003010800050000000b0200000000050000000c021b00ab00040000002e0118001c000000fb020200010000000000bc02000000cc0102022253797374656d003f00003f3f3f3f3f3f3f3f3f3f0800000001003f3f3f3f3f00040000002d010000040000002d01000004000000020101001c000000fb02f5ff0000000000009001000000cc0440002243616c6962726900000000000000000000000000000000000000000000000000040000002d010100040000002d010100040000002d010100050000000902000000020d000000320a0a0000000100040000000000aa001b0020000600040000002d010000040000002d010000030000000000

0100090000032a0200000200a20100000000a201000026060f003a03574d464301000000000001009a7c0000000001000000180300000000000018030000010000006c0000000000000000000000350000006f000000000000000000000091170000b903000020454d46000001001803000012000000020000000000000000000000000000007f120000771a0000c80000001f010000000000000000000000000000000f030058600400160000000c000000180000000a000000100000000000000000000000090000001000000091050000e1000000250000000c0000000e000080250000000c0000000e000080120000000c00000001000000520000007001000001000000a4ffffff00000000000000000000000090010000000000cc04400022430061006c0069006200720069000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000022003097220010000000949a220014982200e450f163949a22008c97220010000000fc982200789a22008a4ff163949a22008c9722002000000080e0b4618c972200949a220020000000ffffffff2c281502fbe0b461ffffffffffff0180ffff01807fff0180ffffffff0030000000080000000800002028720501000000000000005802000025000000372e9001cc00020f0502020204030204ff0200e1ffac004009000000000000009f01000000000000430061006c0069006200720000000000f000ba7654982200334eb661282e9362b49b2200c0972200d532ae612000000001000000fc972200fc9722000076ac6120000000249822002c2815026476000800000000250000000c00000001000000250000000c00000001000000250000000c00000001000000180000000c0000000000000254000000540000000000000000000000350000006f00000001000000e7298740a48e87400000000057000000010000004c00000004000000000000000000000091050000e100000050000000200057003600000046000000280000001c0000004744494302000000ffffffffffffffff92050000e2000000000000004600000014000000080000004744494303000000250000000c0000000e000080250000000c0000000e0000800e000000140000000000000010000000140000000400000003010800050000000b0200000000050000000c021b00ab00040000002e0118001c000000fb020200010000000000bc02000000cc0102022253797374656d003f00003f3f3f3f3f3f3f3f3f3f0800000001003f3f3f3f3f00040000002d010000040000002d01000004000000020101001c000000fb02f5ff0000000000009001000000cc0440002243616c6962726900000000000000000000000000000000000000000000000000040000002d010100040000002d010100040000002d010100050000000902000000020d000000320a0a0000000100040000000000aa001b0020000600040000002d010000040000002d010000030000000000

2.3 Алгоритм процедури Udal












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

uses crt,dos;

type te=record

kal,ves,dl,vis:string[5];

med:string[10];

pr_nom:string[10];

end;

var f:file of te;oru:te;st1,st2,st3,st4,st5:string[20];

x1,x2,y1,y2,i,b:byte;

a1:char;

procedure polo (x1,y1,x2,y2{Љ®®а¤Ё­ вл а ¬ЄЁ ўе®¤­лҐ},

{x01,y01{Љ®®а¤Ё­ вл ўлў®¤ ⥪бв ў а ¬ЄҐ}{:integer;

st{’ҐЄбв ўлў®¤Ё¬л© ў а ¬ЄҐ}{:string;}

a{ЏҐаҐ¬Ґ­­ п д®­ а ¬ЄЁ}:byte);

var i:integer;

begin

textbackground(a);

textcolor(red);

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 menu(x1,y1,x2,y2,a,b:byte;st1,st2,st3,st4,st5:string);

begin

window(1,1,40,25);

clrscr;

window(x1,y1,x2,y2);

textbackground(a);

clrscr;

textcolor(b);

writeln(st1);writeln;

writeln(st2);writeln;

writeln(st3);writeln;

writeln(st4);writeln;

writeln(st5);writeln;

window(1,1,40,25);

textcolor (2);

gotoxy(x1-2,y1);

write('=>');

end;

procedure strelka(var xx,i:byte;x1,y1,a,b:byte);

begin

window(12,6,14,14);

textbackground(0);

clrscr;

window(1,1,40,25);

textcolor(2);

case b of

72: begin

if i>1 then

begin

i:=i-1;

xx:=xx-2;

gotoxy(x1,xx);

write('=>');

exit;

end;

if i=1 then

begin

i:=5;

xx:=y1+8;

gotoxy(x1,xx);

write('=>');

end;

end;

80: begin

if i<5 then

begin

i:=i+1;

xx:=xx+2;

gotoxy(x1,xx);

write('=>');

exit;

end;

if i=5 then

begin

i:=1;

xx:=y1;

gotoxy(x1,xx);

write('=>');

end;

end;

end;

end;

procedure zap;

var i,n:integer;

begin

clrscr;

writeln('vvedi kol-vo orugia');

readln(n);

assign(f,'d:\uy.rer');

rewrite(f);

for i:=1 to n do

begin

with oru do

begin

writeln('vvedi model orugia');

readln(med);

writeln('vvedi kalibr ');

readln(kal);

writeln('vvedi ves ');

readln(ves);

writeln('vvedi dlinu');

readln(dl);

writeln('vvedi visotu');

readln(vis);

writeln('vvedi por.nomer');

readln(pr_nom);

seek(f,filesize(f));

end;

write(f,oru);

end;

close(f);

menu(15,6,27,16,0,14,st1,st2,st3,st4,st5);

end;

procedure udal;

var c:char;

begin

clrscr;

if FSearch('uy.rer','d:\')='' then

begin

writeln('faila ne sushestvuet');

for b:=1 to 25 do

Delay(9999);

menu(15,6,27,16,0,14,st1,st2,st3,st4,st5);

end

else

begin

assign(f,'d:\uy.rer');

writeln('"y"-ydalit basy');

writeln('"n"-otmena');

c:=readkey;

if c='y' then

begin

erase(f);

menu(15,6,27,16,0,14,st1,st2,st3,st4,st5);

end;

if c='n' then

menu(15,6,27,16,0,14,st1,st2,st3,st4,st5);

end;

end;

procedure poisk;

var p,x:string;i:integer;

begin

clrscr;

if FSearch('uy.rer','d:\')='' then

begin

gotoxy(15,12);

textcolor(132);

writeln('zapisi net');

for b:=1 to 40 do

Delay(9999);

menu(15,6,27,16,0,14,st1,st2,st3,st4,st5);

end

else

begin

assign(f,'d:\uy.rer');

reset(f);

writeln('mogno iskat po:');

writeln;

writeln('dla poiska po modeli orugia vvedi-"model"');

writeln;

writeln('dla poiska po kalibru vvedi-"kalibr"');

writeln;

writeln('dla poiska po vesu vvedi-"ves"');

writeln;

writeln('dla poiska po dline vvedi-"dlina"');

writeln;

writeln('dla poiska po visote vvedi-"visota"');

writeln;

writeln('dla poiska po por.nomeru vvedi-"nomer"');

writeln;

writeln('vvedi po hom budem iskat i nagm. "ENTER"');

readln(p);

if (p= 'model') or (p='kalibr') or ( p='ves') or (p='dlina') or (p='visota') or (p='nomer') then

begin

if p='model' then

begin

clrscr;

writeln('vvedi iskaemou model');

readln(x);

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

begin

seek(f,i);

read(f,oru);

with oru do

if x=med then

begin

writeln('model orugia-',med);

writeln(' kalibr-',kal);

writeln(' ves-',ves);

writeln(' dlina-',dl);

writeln(' visota-',vis);

writeln('por.nom-',pr_nom);

end;

end;

end;

if p='kalibr' then

begin

clrscr;

writeln('vvedi iskaeiy kalibr');

readln(x);

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

begin

seek(f,i);

read(f,oru);

with oru do

if x=kal then

begin

writeln('model orugia-',med);

writeln('kalibr-',kal);

writeln('ves-',ves);

writeln('dlina-',dl);

writeln('visota-',vis);

writeln('por.nom-',pr_nom);

end;

end;

end;

if p='ves' then

begin

clrscr;

writeln('vvedi iskaeiy ves');

readln(x);

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

begin

seek(f,i);

read(f,oru);

with oru do

if x=ves then

begin

writeln('model orugia-',med);

writeln('kalibr-',kal);

writeln('ves-',ves);

writeln('dlina-',dl);

writeln('visota-',vis);

writeln('por.nom-',pr_nom);

end;

end;

end;

if p='dlina' then

begin

clrscr;

writeln('vvedi iskaemou dliny');

readln(x);

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

begin

seek(f,i);

read(f,oru);

with oru do

if x=dl then

begin

writeln('model orugia-',med);

writeln('kalibr-',kal);

writeln('ves-',ves);

writeln('dlina-',dl);

writeln('visota-',vis);

writeln('por.nom-',pr_nom);

end;

end;

end;

if p='visota' then

begin

clrscr;

writeln('vvedi iskaemou visotu');

readln(x);

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

begin

seek(f,i);

read(f,oru);

with oru do

if x=vis then

begin

writeln('model orugia-',med);

writeln('kalibr-',kal);

writeln('ves-',ves);

writeln('dlina-',dl);

writeln('visota-',vis);

writeln('por.nom-',pr_nom);

end;

end;

end;

if p='nomer' then

begin

clrscr;

writeln('vvedi iskaemiy por.nomer');

readln(x);

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

begin

seek(f,i);

read(f,oru);

with oru do

if x=pr_nom then

begin

writeln('model orugia-',med);

writeln('kalibr-',kal);

writeln('ves-',ves);

writeln('dlina-',dl);

writeln('visota-',vis);

writeln('por.nom-',pr_nom);

end;

end;

end

end

else writeln('po' ,p,'poisk ne idet');

close(f);

end;

readln;

menu(15,6,27,16,0,14,st1,st2,st3,st4,st5);

end;

procedure prosm;

var i,j:integer;

begin

clrscr;

if FSearch('uy.rer','d:\')='' then

begin

gotoxy(15,12);

textcolor(132);

writeln('zapisi net');

for b:=1 to 40 do

Delay(9999);

menu(15,6,27,16,0,14,st1,st2,st3,st4,st5);

end

else

begin

assign(f,'d:\uy.rer');

reset(f);

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

begin

seek(f,i);

read(f,oru);

with oru do

begin

writeln('zapis-',i+1);

writeln('model orugia-',med);

writeln(' kalibr-',kal);

writeln(' ves-',ves);

writeln(' dlinu-',dl);

writeln(' visotu-',vis);

textcolor(2);

for j:=1 to 80 do

write(#205);

end;

end;

close(f);

end;

readln;

menu(15,6,27,16,0,14,st1,st2,st3,st4,st5);

end;

begin

textmode(co40);

window(1,1,40,25);

clrscr;

st1:='novaya basa';

st2:='udalit basu';

st3:='poisk v base';

st4:='prosmotr ';

st5:='exit';

menu(15,6,27,16,0,14,st1,st2,st3,st4,st5);

x1:=13;y1:=6;y2:=6;

i:=1;

repeat

repeat

newreadkey(a1,b);

strelka(y2,i,x1,y1,6,b);

until a1=#13;

case i of

1:zap;

2:udal;

3:poisk;

4:prosm;

5:halt;

end;

until a1=#27;

end.

Висновок

В даній курсовій роботі були використані елементи програмування на мові Паскаль. Була створена програма, яка веде облік вогнепальної зброї. Таким чином біли виконані всі вимоги до даної курсової роботи.

В даній роботі було створено досить велику кількість процедур, які можливо використати і в інших програмних проектах, були використані різні типи даних, а також були застосовані процедури та функції які були створені раніше, ці процедури та функції я брав з модулів CRT та DOS.

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

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

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

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