Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
МУ Теория алгоритмов - БИ-1.docx
Скачиваний:
111
Добавлен:
30.05.2015
Размер:
4.19 Mб
Скачать
  1. Содержание работы

Работа предполагает базовые знания школьного курса языка программирования Turbo Pascal. Запустить программуPascal ABC. Ознакомиться с работой программы, строкой меню, окном редактора кода и ввода-вывода команд. Воспроизвести примеры, приведенные ниже, используя, где необходимо, преобразование команд «школьного алгоритмического языка» в операторы паскаля. По указанию преподавателя выбрать вариант из Приложения Д. По завершении работы результаты сохранить в файл.

  1. Задан одномерный массив X1, X2, …,XN . Фрагмент алгоритма определяет произведение отрицательных элементов с четными номерами.

  1. Пример фрагмента блок-схемы

  1. Вычислить сумму элементов числового массива A = (a1 , a2 , ... , aN).

Для решения задачи используем циклический алгоритм. Подготовка цикла заключается в задании начального значения суммы, равного нулю. В качестве параметра цикла берем номер члена последовательности. Начальное значение параметра цикла равно 1, конечное значение – числу членов последовательности, шаг цикла +1. В теле цикла выполняется последовательное суммирование. Окончание цикла будет при значении параметра цикла, превышающего количество членов последовательности.

Program Summa;

  Uses Crt;

  Type Mas = Array [1..20] of Real;

  Var A : Mas;

i, N : Integer;

S : Real;

BEGIN

  ClrScr; {очистка экрана }

  Write('Введите N = ');

  ReadLn(N); {ввод значения N}

  For i := 1 to N dо {цикл по элементам массива}

begin

Write('A [ ', i , ' ] = ');

ReadLn(A[i]){ввод элементов массива}

end;

  S := 0; {присваивание начального значения}

  For i := 1 to N do S := S+A[i]; {суммирование}

  WriteLn;

  WriteLn('Сумма равна ', S : 5 : 1);

  ReadLn

END.

  1. Найти наибольший элемент числового массива A = (a1, a2 , ..., aN) и его номер.

Program MaxElem;

Uses Crt;

Type Mas = Array [1..20] of Real;

Var A : Mas;

i, N : Integer;

k : Integer;

Amax : Real;

BEGIN

СlrScr;

Write('Введите N = ');

ReadLn(N);

For i := 1 to N do {Ввод значений элементов массива А}

begin

Write('A [ ', i, ' ] = '); ReadLn(A[i])

end;

Amax := A[1]; k:=1; {Поиск максимального элемента}

For i := 2 to N do

If A[i] > Amax then

begin

Amax := A[i]; k := i

end;

WriteLn; WriteLn('Наибольший элемент' , k , '-й');

WriteLn('Его значение ', Amax : 5 : 1); ReadLn

END.

  1. Пример 4. В баскетбольную команду могут быть приняты студенты, рост которых превышает 170 см. Составьте список кандидатов в команду из студентов класса.

N теста

I

Рост[i] > 170

K

Кандидаты в команду

1

1

2

3

+

-

+

0

1

2

Кулов

Уваров

2

1

2

-

-

0

-

 

Program BascetBall;

  Uses Crt;

  Var

SurName : Array [1..30] of String;  { фамилии студентов }

Height  : Array [1..30] of Real; { рост студентов }

Cand : Array [1..30] of String;  { фамилии кандидатов }

NPupil, i, K : Integer; { NPupil - число студентов,

K - количество зачисленных}

BEGIN ClrScr;

  Write('В КОМАНДУ ЗАЧИСЛЯЮТСЯ студенты, ');

  WriteLn('РОСТ КОТОРЫХ ПРЕВЫШАЕТ 170 СМ.'); WriteLn;

  Write('Сколько всего студентов ? ');

  ReadLn(NPupil);

  WriteLn('Введите фамилии и рост студентов :');

  For i := 1 to NPupil do

begin Write(i, '. Фамилия - '); ReadLn(SurName[i]);

Write(' Рост - '); ReadLn(Height[i]);

end; WriteLn;

  K:=0; { Составление списка команды }

  For i := 1 to NPupil do

If Height[i]>170 then

begin K:=K+1; Cand[K] := SurName[i] end;

  If K=0 then WriteLn('В ГРУППЕ НЕТ КАНДИДАТОВ В КОМАНДУ.')

else

 begin WriteLn('КАНДИДАТЫ В БАСКЕТБОЛЬНУЮ КОМАНДУ :');

For i := 1 to K do WriteLn( i, '. ' , Cand[i]);

end;

  ReadLn

END.

  1. Дан массив X(N). Получить новый массив Y(N) такой, что в нем сначала идут положительные числа, затем нулевые, и затем отрицательные из X.

Данные

Результат

N=7

X=(-1, 2, 0, 4, -3,-2,0)

Y=(2, 4, 0, 0, -1, -3, -2)

Program NewOrder;

Uses Crt;

Var N, i, k : Integer;

X, Y : Array [1..20] of Real;

BEGIN

ClrScr;

Write('Введите N = '); ReadLn(N);

For i := 1 to N do

begin

Write('X[ ', i, ' ] = '); ReadLn(X[i])

end;

k:=0;

For i := 1 to N do

If X[i]>0 then

begin k:=k+1; Y[k]:=X[i]

end;

For i := 1 to N do

If X[i]=0 then

begin k:=k+1; Y[k]:=X[i]

end;

For i := 1 to N do

If X[i]<0 then

begin k:=k+1; Y[k]:=X[i]

end;

Write('О т в е т : полученный массив');

For i := 1 to N do Write(Y[i] : 5 : 1);

WriteLn; ReadLn

END

  1. Заполнить матрицу порядка n по следующему образцу:

1

2

3

...

n-2

n-1

n

2

1

2

...

n-3

n-2

n-1

3

2

1

...

n-4

n-3

n-2

...

...

...

...

...

...

...

n-1

n-2

n-3

...

2

1

2

n

n-1

n-2

...

3

2

1

Program Massiv12;

Var I, J, K, N : Integer; A : Array [1..10, 1..10] Of Integer;

Begin

Write('Введите порядок матрицы: '); ReadLn(N);

For I := 1 To N Do

For J := I To N Do

Begin

A[I, J] := J - I + 1; A[J, I] := A[I, J];

End;

For I := 1 To N Do

Begin

WriteLn;

For J := 1 To N Do Write(A[I, J]:4);

End

End.

Задача 7. Дана целочисленная квадратная матрица. Найти в каждой строке наибольший элемент и поменять его местами с элементом главной диагонали.

Program Obmen;

Var N, I, J, Max,Ind, Vsp : Integer;A : Array [1..15, 1..15] Of Integer;

Begin

WRITE('Введите количество элементов в массиве: '); READLN(N);

FOR I := 1 TO N DO

FOR J := 1 TO N DO

Begin

WRITE('A[', I, ',', J, '] '); READLN(A[I, J])

End;

FOR I := 1 TO N DO

Begin

Max := A[I, 1]; Ind := 1;

FOR J := 2 TO N DO

IF A[I, J] > Max THEN

Begin

Max := A[I, J]; Ind := J

End;

Vsp := A[I, I]; A[I, I] := A[I, Ind]; A[I, Ind] := Vsp

End;

FOR I := 1 TO N DO

Begin

WriteLn;

FOR J := 1 TO N Do Write(A[I, J] : 3);

End; WriteLn

End.