Помощь - Поиск - Пользователи - Календарь
Полная версия: Задача на перечислимый тип
Форум «Всё о Паскале» > Pascal, Object Pascal > Задачи
TORETO
Часть кода программы:

type rep=(Russia,Ukraina,Gruzia,Belorussia,Azerbaijan);
var
NBH:array[rep,rep] of boolean;
r:rep;



Элемент NBH[a,b] равен true, если страны a и b имеют общую границу, и равен false иначе.Определить r-страну, имеющую наибольшее число соседей среди перечисленных стран.

Буду благодарен любой помощи!
volvo
Что-то вот такого типа:

type
rep = (
Russia, Ukraina, Gruzia, Belorussia, Azerbaijan
);
var
NBH: array[rep, rep] of boolean;
i, j, r: rep;
max, count: integer;

begin

{ Здесь - добавить заполнение матрицы }

max := 0;
r := low(rep);
for i := low(rep) to high(rep) do begin
count := 0;
for j := low(rep) to high(rep) do
if NBH[i, j] then inc(count);

if max < count then begin
r := i; max := count;
end;
end
{ в R содержится искомая страна }
end.

TORETO
Как заполнить матрицу,через case как-то или другим способом? Никак не пойму.Объясните!
Client
Просто так НЕЛЬЗЯ вводить/выводить значения перечислимого типа. Тебе надо добавить переменную целого типа и в зависимости от ее значения с помощью case'а определить страну (если оно тебе надо)
volvo
Можно вообще задать матрицу типизированной константой, кстати...

const
NBH: array[rep, rep] of boolean = (
{ru} {ua} {gr} {by} {md}
(false, false, false, false, false), { Россия граничит с ... }
(false, false, false, false, false), { Украина граничит с ... }
(false, false, false, false, false), { Грузия граничит с ... }
(false, false, false, false, false), { Белоруссия граничит с ... }
(false, false, false, false, false) { Молдова граничит с ... }
);

Поменяй где есть границы false на true, и все...
TORETO
Нет.Так нельзя должно быть что-то наподобие:


case x of
0: r:=Russia;
1: r:=Gruzia;
......
end;



А вот как дальше то делать?
TORETO
Вот, что неправильно? Не могу найти нужную страну и вывести ее


program Lab7;
uses crt;
type
rep=(Russia,Ukraina,Gruzia,Belorussia,Azerbaijan);
var
NBH:array[rep,rep] of boolean;
r:rep;
max,count,i,j,k:integer;
begin
clrscr;
max:=0;
for i:=0 to 4 do begin
case i of
0: writeln('Russia granichit s');
1: writeln('Ukraina granichit s');
2: writeln('Gruzia granichit s');
3: writeln('Belorussia granichit s');
4: writeln('Azerbaijan granichit s');
end;
for j:=0 to 4 do begin
case j of
0:writeln('Russia:');
1:writeln('Ukraina:');
2:writeln('Gruzia:');
3:writeln('Belorussia:');
4:writeln('Azerbaijan:');
end;
readln(k);
if k=1 then
NBH[rep(i),rep(j)]:=true else
NBH[rep(i),rep(j)]:=false;
writeln(NBH[rep(i),rep(j)]);
r:=rep(0);
max:=0;
for i:=0 to 4 do begin
count:=0;
for j:=0 to 4 do
if NBH[rep(i),rep(j)] then inc(count);
if max<count then begin
r:=rep(i);
max:=count;
end;
end;
end;
end;
writeln(NBH[rep(i),rep(j)]);
readln;
end.


TORETO



program Lab7;
uses crt;
type
rep=(Russia,Ukraina,Gruzia,Belorussia,Azerbaijan);
var
NBH:array[rep,rep] of boolean;
r:rep;
max,count,i,j,k:integer;
begin
clrscr;
max:=0;
for i:=0 to 4 do begin
case i of
0: writeln('Russia granichit s');
1: writeln('Ukraina granichit s');
2: writeln('Gruzia granichit s');
3: writeln('Belorussia granichit s');
4: writeln('Azerbaijan granichit s');
end;
for j:=0 to 4 do begin
case j of
0:writeln('Russia:');
1:writeln('Ukraina:');
2:writeln('Gruzia:');
3:writeln('Belorussia:');
4:writeln('Azerbaijan:');
end;
readln(k);
case k of
0:NBH[rep(i),rep(j)]:=false;
1:NBH[rep(i),rep(j)]:=true;
end;
writeln(NBH[rep(i),rep(j)]);
end;
end;
readln;
end.



Вот.Массив вроде заполняется.Как теперь найти нужную страну?
TORETO
Вот чут-чуть осталось доделать.Нужно еще найти максимальное значение счетчика count.Помогите это сделать и еще как вывести страну.Я знаю что это несложно, но не получается у меня.Вот код:

program Lab7;
uses crt;
type
rep=(Russia,Ukraina,Gruzia,Belorussia,Azerbaijan);
var
NBH:array[rep,rep] of boolean;
r:rep;
max,count,i,j,k,a:integer;
begin
clrscr;
for i:=0 to 4 do begin
case i of
0: writeln('Russia granichit s');
1: writeln('Ukraina granichit s');
2: writeln('Gruzia granichit s');
3: writeln('Belorussia granichit s');
4: writeln('Azerbaijan granichit s');
end;
for j:=0 to 4 do begin
case j of
0:writeln('Russia:');
1:writeln('Ukraina:');
2:writeln('Gruzia:');
3:writeln('Belorussia:');
4:writeln('Azerbaijan:');
end;
readln(k);
case k of
0:NBH[rep(i),rep(j)]:=false;
1:NBH[rep(i),rep(j)]:=true;
end;
if NBH[rep(i),rep(j)] then
count:=count+1;
end;
writeln('Kol-vo sosedei ',count);
if count>0 then
count:=0;
end;
readln;
end.


Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.