Форум: "Основная";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.03.25;
Скачать: [xml.tar.bz2];




Вниз

Хитрая задачка с перебором массивов 


greenrul   (2002-03-10 11:12) [0]

Есть два массива 1..5 - L и K, в обоих есть string до i3 номера (т.е. если i3=2 то L[1],L[2],K[1],K[2]) существуют. Задача - сверить, все ли эл-ты массива K присутствуют во всех эл-так массива L (порядок неважен, но совпадение полное).

Пример -
i3:=3

K[1]=Ctrl
K[2]=Shift
K[3]=Alt

L[1]=Alt
L[2]=Shift
L[3]=Ctrl

дает истину, НО

i3:=3
K[1]=Ctrl
K[2]=Shift
K[3]=Up

L[1]=Alt
L[2]=Shift
L[3]=Ctrl

дает ложь....


Я писал -
kill:=0;
i4:=0;
for i:=1 to i3 do
for i2:=1 to i3 do
if (k[i]=l[i2]) and (kill<>1) then begin kill:=2; i4:=i2; end
else if i4<>i2 then kill:=1;
if (kill=2) then
ShowMessage("YES!")


в чем моя ошибка?



Mbo   (2002-03-10 11:26) [1]

подразумевается, что в K элементы не повторяются
function ...
begin
result:=false;
for i:=1 to i3 do begin
t:=true;
for i2:=1 to i3 do if k[i]=l[i2] then t:=false;
if t then exit;
end;
result:=true;
end;



cdaDmitriy   (2002-03-10 11:31) [2]

for i:=1 to i3 do Begin
kill:=0;
for i2:=1 to i3 do
if (k[i]=l[i2]) then begin kill:=2; break; end;
IF (kill=0) then begin kill:=3; break; end;
End

if (kill<>3) then ShowMessage("YES!")



greenrul   (2002-03-10 11:33) [3]

СПАСИБО!!!
оба подощли




Форум: "Основная";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.03.25;
Скачать: [xml.tar.bz2];




Наверх





Память: 0.72 MB
Время: 0.023 c
1-80519           Rail                  2002-03-13 07:28  2002.03.25  
QReport ГЛЮЧИТ !!!


3-80435           Antony                2002-02-27 12:14  2002.03.25  
TQuery.Prepare, сильные утечки памяти


7-80701           vvvico                2001-12-20 12:12  2002.03.25  
Проблемка с W2K


1-80555           VD                    2002-03-09 08:44  2002.03.25  
Как перехватить принудительное закрытие программы?


4-80729           Igor_thief            2002-01-24 15:26  2002.03.25  
Button