Технический форум
Вернуться   Технический форум > Программирование > Форум программистов > Помощь студентам


Ответ
 
Опции темы Опции просмотра
Старый 31.03.2012, 14:00   #1 (permalink)
virginia
Member
 
Регистрация: 29.10.2011
Сообщений: 42
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: -42
По умолчанию Логический вектор. Паскаль

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

Старый 31.03.2012, 14:00
Helpmaster
Member
 
Аватар для Helpmaster
 
Регистрация: 08.03.2016
Сообщений: 0

Пока вы ждете ответов в вашу тему, можете ознакомиться с этими темами

Пропал логический диск
Турбо Паскаль или Фри Паскаль. Задание по теме Типизированный файл

Старый 31.03.2012, 14:29   #2 (permalink)
Vladimir_S
Специалист
 
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
По умолчанию

Цитата:
Сообщение от virginia Посмотреть сообщение
Пусть дана матрица А (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.
Vladimir_S вне форума   Ответить с цитированием
Старый 31.03.2012, 14:54   #3 (permalink)
virginia
Member
 
Регистрация: 29.10.2011
Сообщений: 42
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: -42
По умолчанию

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;
а что в этой части делается?
virginia вне форума   Ответить с цитированием
Старый 31.03.2012, 16:08   #4 (permalink)
Vladimir_S
Специалист
 
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
По умолчанию

Цитата:
Сообщение от virginia Посмотреть сообщение
а что в этой части делается?
Проверка на наличие совпадений значений элементов вектора. Если таковое встречается, то выполнение циклов прекращается и функция получает значение TRUE, если нет - FALSE. В процессе работы программы в качестве аргумента подставляются векторы-строки исходной матрицы. Ибо речено в Задании свыше:
Цитата:
Воспользуйтесь логической функцией, которая для i-й строки выполняет указанную проверку.
Вот... нарисовал такую функцию, да и воспользовался.
Vladimir_S вне форума   Ответить с цитированием
Ads

Яндекс

Member
 
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
Ответ

Опции темы
Опции просмотра

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Выкл.
HTML код Выкл.
Trackbacks are Вкл.
Pingbacks are Вкл.
Refbacks are Выкл.




Часовой пояс GMT +4, время: 22:59.

Powered by vBulletin® Version 6.2.5.
Copyright ©2000 - 2014, Jelsoft Enterprises Ltd.