• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о проекте и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Срочно нужна блок схема к коду

  • Автор темы Автор темы Oleg9
  • Дата начала Дата начала

Oleg9

Ученик
Регистрация
12 Сен 2014
Сообщения
1
Реакции
0
Баллы
0
Срочно нужна блок схема к коду

program lab;
uses crt;
const
count=100;{максимальное кол-во данных}
type
Data=record{структура}
fam:string[20];{фамилия}
st:integer;{стаж}
end;
var
a:array[1..count] of Data;{массив структур}
tmp: Data;{временная переменная для сортировки нужна}
n,i,st,s,j:integer;
ch:string;
f,check:boolean;
dg:string;
fl:text;
begin
assign(fl,'data.txt');{связываем файловую переменную с физически файлом на диске}
rewrite(fl);{перезеписываем файл}
s:=0;
repeat
write('Vvedite kol-vo zapisey :');{кол-во записей считываем}
readln(dg);
val(dg,n,j);{переводим в число}
until j=0;{в переменную у нас записывается код ошибки}
for i:=1 to n do
begin
repeat
check:=false;
write('Vvedite familiyu :');
readln(a.fam);{считываем фамилию}
for j:=1 to length(a.fam) do
if a.fam[j] in ['0'..'9']then check:=true;
until check=false;
repeat
write('Vvedite staj :');
readln(dg);{считываем}
val(dg,a.st,j);{переводим в число}
until j=0;{в переменную у нас записывается код ошибки}
writeln(fl,'Familiya :',a.fam:15,' Staj :',a.st:2);{выводим в файл}
end;
close(fl);
clrscr;
for i:=1 to n do
writeln('Familiya :',a.fam:15,' Staj :',a.st:2);{выводим все}
writeln;
for i:=1 to n do
s:=s+a.st;{среднее вычисляем}
s:=s div n;
repeat
check:=false;
write('Vvedite bukvu :');
writeln;
readln(ch); {считываем букву}
for j:=1 to length(ch) do
if ch[j] in ['0'..'9']then check:=true;
until check=false;
for i:=1 to n do
if a.fam[1]=ch then writeln('Familiya :',a.fam:15,' Staj :',a.st:2);
{выводим где фамилия начинается с введенной буквы}
writeln;
repeat
write('Vvedite staj :');
readln(dg); {стаж}
val(dg,st,j);{переводим в число}
until j=0;{в переменную у нас записывается код ошибки}
for i:=1 to n do
if a.st=st then writeln('Familiya :',a.fam:15,' Staj :',a.st:2);
writeln;
writeln('Staj > sr :');{стаж выводим если больше среднего}
for i:=1 to n do
if a.st>s then writeln('Familiya :',a.fam:15,' Staj :',a.st:2);
writeln;
writeln('V alf poryadke :');{выводим в алфавитном порядке}
repeat{сортировка обменами}
f:=false;
for i:=1 to n-1 do
if a.fam>a[i+1].fam then {если условие выполняется то обмен}
begin
f:=true;
tmp:=a;
a:=a[i+1];
a[i+1]:=tmp;
end;
until f=false;
for i:=1 to n do{выводим}
writeln('Familiya :',a.fam:15,' Staj :',a.st:2);
writeln('Staj ubivaet :');{сортировка по убыванию стажа}
repeat
f:=false;
for i:=1 to n-1 do
if a.st<a[i+1].st then
begin
f:=true;
tmp:=a;
a:=a[i+1];
a[i+1]:=tmp;
end;
until f=false;
for i:=1 to n do{выводим}
writeln('Familiya :',a.fam:15,' Staj :',a.st:2);
readln;
end.
 
Ну это ж элементарно.
 
Назад
Сверху