Задание 2. Работа в группе. Разделение класса на 4 группы, Каждая группа проводит обсуждение содержания «Нигерий-
2. Выделите в нем моменты, указывающие на то, что это спати,
3. Перечислите факты, указанные в письме, которые кажутся
ского письма».
1. Внимательно прочитайте текст письма.
вам недостоверными и подозрительными.
4. Проведите коллективное обсуждение содержания «иигерий
ских писем».
Вопросы для обсуждения:
1. Как можно распознать «нигерийское письмо»?
2. Как вы думаете, кто авторы «Нигерийских писем »?
3. Какую цель преследуют авторы «Нигерийских писем»?
4. Какова степень опасности «нигерийских писем»?
стал
Письмо № 1
«Меня зовут Бакаре Тунде, я брат первого нигерийского
астронавта, майора ввс Нигерии Абака Тунде. Мой брат
первым африканским астронавтом, который отпра-
вился с секретной миссией на советскую станцию «Салют-6,
в далеком 1979 году. Позднее он принял участие в полете
советского «Союза Т-163» к секретной советской космической
станции «Салют-8Т». В 1990 году, когда СССР распался, он
находился на станции. Все русские члены команды сумели
вернуться на Землю, однако моему брату не хватило на корабле
места. С тех пор и до сегодняшнего дня он вынужден находиться
на орбите, лишь редкие грузовые корабли «Прогресс» снабжают
его необходимыми продуктами. Несмотря ни на что мой брат
не теряет присутствия духа, однако жаждет вернуться домой,
в родную Нигерию. За те долгие годы, что он провел в космосе,
var a : array [1..3, 1..4] of integer
b : array [1..3] of integer
Max, i, j : integer
BEGIN
crt;
for i:=1 to 3 do
begin
for j:=1 to 4 do
begin
read (a[i, j]); // вводим элементы в массив a[1..3, 1..4]
end;
writeln; // делаем пустой перевод строки
end;
for i:=1 to 3 do
begin
b[i] := a[i, 1];
for j:=1 to 4 do
begin
if a[i, j] > b[i] then b[i] := a[i, j];
// находим максимальный элемент в каждой строке и записываем в b[1..3]
end;
end;
Max := b[1];
for i:=1 to 3 do if b[i] > Max then Max := b[i];
// Находим максимальный элемент из максимальных элементов
writeln (Max); // Выводим его на экран
END.
// PascalABC.Net 3.0, сборка 1066
procedure CheckString(var s:string; var n:integer);
var
i:integer;
begin
i:=Length(s);
while i>0 do begin
if not(s[i] in ['a'..'z']) then Delete(s,i,1);
Dec(i)
end;
n:=Length(s)
end;
var
s1,s2:string;
i,p,n1,n2:integer;
begin
Write('Введите первую строку: '); Readln(s1);
CheckString(s1,n1);
if n1=0 then Writeln('Введенная строка не содержит допустимых символов')
else begin
Write('Введите вторую строку: '); Readln(s2);
CheckString(s2,n2);
if n2=0 then Writeln('Введенная строка не содержит допустимых символов')
else
{ теперь обе строки содержат только маленькие латинские буквы }
if n1=n2 then begin
for i:=1 to n1 do begin
p:=Pos(s1[i],s2);
if p=0 then Break
else Delete(s2,p,1)
end;
if Length(s2)=0 then Writeln('Решение имеется')
else Writeln('Решения нет')
end
else
Writeln('Решения нет');
end
end.
Тестовое решение:
Введите первую строку: this is my own deal!
Введите вторую строку: Тест: *is now=l2ead my sthi?
Решение имеется
Также имеется современное решение, которому пока что в школах не учат:
// PascalABC.Net 3.0, сборка 1066
begin
var s1:=ReadString('Введите первую строку: ').Where(x->x in ['a'..'z']);
if s1.Count=0 then
Writeln('Введенная строка не содержит допустимых символов')
else begin
var s2:=ReadString('Введите вторую строку: ').Where(x->x in ['a'..'z']);
if s2.Count=0 then
Writeln('Введенная строка не содержит допустимых символов')
else
if s1.Except(s2).Count>0 then Writeln('Решения нет')
else Writeln('Решение имеется')
end
end.