milana23456789
27.08.2021 01:35

Ориентированный граф называется турниром, если между любой парой его различных вершин существует ровно одно ребро. Для заданного списком ребер графа проверьте, является ли он турниром. Входные данные
Сначала вводятся числа n ( 1≤n≤100 ) – количество вершин в графе и m ( 1≤m≤n(n−1) ) – количество ребер. Затем следует m пар чисел – ребра графа.

Выходные данные
Выведите «YES», если граф является турниром, и «NO» в противном случае.

МОЙ КОД:
var m,n,i,j,q,x,p,y: integer;
no: array [1..1000, 1..1000] of longint;
begin
read(n, m);

for i:= 1 to m do
begin
readln(x, y);
no[x, y]:= no[x, y] + 1;
end;

for j:= 1 to n do
for q:= 1 to n do
begin
if (j q) then
if (no[j, q] = 0) and (no[q, j] = 0) or (no[j, q] > 1) or (no[q, j] > 1) then
begin
write('NO');
halt
end
else
begin
continue
end;
end;
write('YES');
end.

Скажите что не так

Нажмите на рекламу ниже и сразу увидите ответ
Популярные вопросы:
Ответ:
Sanya3110
28.02.2020 18:50
У вас есть число 137
если вам надо перевести его в какую-нибудь систему счисления, то нужно делить это число на номер системы, так если нужно перевести число 137 в ДВОичную ,то делим на 2 до тех пор, пока остатотк от деления не равен 1.(если в ТРОичную то на 3 и т.д.).
начнём:
137 / 2 = 68 выписываем остаток (1) 
68   / 2 = 34 выписываем остаток (0)
34   / 2 = 17 выписываем остаток (0)
17   / 2 = 8   выписываем остаток (1)
8     / 2 = 4   выписываем остаток (0)
4     / 2 = 2   выписываем остаток (0)
2     / 2 = 1  <==   на этой единице заканчиваем деление, далее снизу вверх выписываем получившееся число : 001001;
ответ: 001001
0,0(0 оценок)
Ответ:
Элина17539
13.12.2021 09:51
1)
var
a:array[1..20] of integer;
index, Min,count, i, n:integer;
begin
Readln(n);
Min:= 81;index:=-1;
For i:= 1 to n do
  begin
    a[i]:= random(96) - 15;
    Write(a[i], ' ');
    if Min = a[i] then
      count:= count+1;
    if Min > a[i] then begin
        Min:=a[i];
        index:=i;
        count:=1;
      end;
  end;
Writeln;
Writeln('Min = ', Min);
Writeln('Минимумов: ', count, ' их сумма равна ', count*Min);
for i:= n downto 2 do
  if (a[i] < 0) and (a[i-1] < 0) then
    begin
      Write('Номера соседних отрицательных эл-в -> ');
      Writeln(i-1, ' ', i);
      break;
    end;
end.

Пример:
20
59 -3 44 -15 60 -3 70 -15 -10 1 -1 -2 21 23 -5 24 45 -10 0 48
Min = -15
Минимумов: 2 их сумма равна -30
Номера соседних отрицательных эл-в -> 11 12

2)

var
a,b:array[1..200] of integer;
i, n,cnt, j, Max:integer;
begin
Readln(n);
Read(a[1]);Max:=a[1];cnt:=1;
For i:= 2 to n do
 begin
 Read(a[i]);
 if a[i] = max then
  cnt:= cnt+1;
 if a[i] > max then
 begin
  max:=a[i];
  cnt:=1;
 end;
 end;
 j:=1;
 for i:=1 to n do
  if a[i] < Max then
    begin
      b[j]:=a[i];
      j:= j+1;
    end;
 for i:= j to n do
  b[i]:=Max;
 for i:=1 to n do
  Write(b[i], ' ');
end.

Пример:
6
1 5 3 2 5 0
1 3 2 0 5 5

type Info =  record
name:string;
unpl:integer;//unemployment
end;

var
a:array[1..40] of Info;
tmp:Info;
i, j:integer;
begin
For i:= 1 to 40 do
  begin
    Readln(a[i].name);
    Readln(a[i].unpl);
  end;
For i:= 1 to 40 do
  for j:= i to 40 do
    if a[i].unpl > a[j].unpl then
      begin
        tmp.name:= a[i].name;
        tmp.unpl:= a[i].unpl;
        a[i].name:=a[j].name;
        a[i].unpl:=a[j].unpl;
        a[j].name:=tmp.name;
        a[j].unpl:=tmp.unpl;
      end;
 Writeln('три неблагополучных района:')
 Writeln(a[40].name);
 Writeln(a[39].name);
 Writeln(a[38].name);
 Writeln('три наиболее благополучных');
 Writeln(a[1].name);
 Writeln(a[2].name);
 Writeln(a[3].name);
end.

Формат Ввода:
Название района
Безработица
0,0(0 оценок)
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota Оформи подписку
logo
Начни делиться знаниями
Вход Регистрация
Что ты хочешь узнать?
Спроси ai-бота