База даних по обліку вогнепальної зброї
Міністерство внутрішніх справ України
Харківський національний університет внутрішніх справ
Навчально-науковий інститут менеджменту, соціальних та інформаційних технологій
Кафедра інформаційних систем і технологій в діяльності ОВС
Курсова робота
з дисципліни «Основи програмування та алгоритмічні мови»
на тему: «База даних по обліку вогнепальної зброї»
Харків р.
Зміст
Вступ
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 с.: ил.