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

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

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

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

Логический вектор. Паскаль

virginia

Новые
Регистрация
29 Окт 2011
Сообщения
42
Реакции
0
Баллы
0
Логический вектор. Паскаль

Пусть дана матрица А (n x n). Постройте логический вектор, каждый элемент которого принимает значение true, если среди элементов i-того строки матрицы А есть хотя бы два равных, и значение false - иначе. Воспользуйтесь логической функцией, которая для i-й строки выполняет указанную проверку.
можно объяснить просто как делать
 
Пусть дана матрица А (n x n). Постройте логический вектор, каждый элемент которого принимает значение true, если среди элементов i-того строки матрицы А есть хотя бы два равных, и значение false - иначе. Воспользуйтесь логической функцией, которая для i-й строки выполняет указанную проверку.
можно объяснить просто как делать
Легко:
Код:
Const
 N=8;

Type Ar=Array[1..N] of Byte;

Var
 A:Array[1..N] of Ar;
 i,j:Byte;
 Bu:Array[1..N] of Boolean;

Function Tst(Q:Ar):Boolean;
var
 k,m:Byte;
 b:Boolean;
begin
 b:=false;
 k:=0;
 Repeat
  Inc(k);
  m:=k;
  Repeat
   Inc(m);
   If Q[k]=Q[m] then b:=true;
  Until b or (m=N);
 Until b or (k=N-1);
 Tst:=b;
end;

Begin
 Randomize;

 For i:=1 to N do
  begin
   For j:=1 to N do
    A[i][j]:=Random(50);
   Bu[i]:=Tst(A[i]);
  end;

 For i:=1 to N do
  begin
   For j:=1 to N do
    write(A[i][j]:4);
   write('  ');
   writeln(Bu[i]);
  end;

 Readln
End.
 
Function Tst(Q:Ar):Boolean;
var
k,m:Byte;
b:Boolean;
begin
b:=false;
k:=0;
Repeat
Inc(k);
m:=k;
Repeat
Inc(m);
If Q[k]=Q[m] then b:=true;
Until b or (m=N);
Until b or (k=N-1);
Tst:=b;
end;
а что в этой части делается?
 
а что в этой части делается?
Проверка на наличие совпадений значений элементов вектора. Если таковое встречается, то выполнение циклов прекращается и функция получает значение TRUE, если нет - FALSE. В процессе работы программы в качестве аргумента подставляются векторы-строки исходной матрицы. Ибо речено в Задании свыше:
Воспользуйтесь логической функцией, которая для i-й строки выполняет указанную проверку.
Вот... нарисовал такую функцию, да и воспользовался.
 
Назад
Сверху