Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2010.08.27;
Скачать: CL | DM;

Вниз

Поиск оптимума пересмотром всех значений   Найти похожие ветки 

 
webpauk ©   (2010-05-18 09:08) [0]

суть задачи такова:
CONST - (X*Const1+Y*Const2+Z*Const3+...)<=0.01

Реализация сводится к пересмотру в цикле всех вариантов:


const
 CONSTMain = 12345;
var
 I1, I2, I3...: Integer;
begin
 for I1 = 1 to ... do
 begin
   for I2 = 1 to ... do
   begin
     if CONSTMain-(I1*Const1+I2*Const2)<=0.01 then Exit;
   end;
 end;
end;


проблема в следующем: имеется неопределенное количество переменных, значения которых нужно исследовать, соответственно и не определено количество вложенных циклов.
Каким образом можно определить переменную цикла (I1, I2...), чтобы её можно было сделать зависимой от количества переменных?


 
webpauk ©   (2010-05-18 09:10) [1]

типичной ошибкой при использовании неопределенной переменной будет: For loop control variable must be simple local variable


 
MBo ©   (2010-05-18 09:15) [2]

рекурсия поможет.

А вообще это задача целочисленного линейного программирования.


 
Омлет ©   (2010-05-18 20:38) [3]

Откуда берутся переменные?


 
Юрий Зотов ©   (2010-05-18 21:31) [4]


webpauk ©   (18.05.10 09:08)
> не определено количество вложенных циклов.


Рекурсия.

procedure Proc(Params: ...)
var
 i: integer;
begin
 ...
 for i := ... to ... do
 begin
   ...
   if ... then Proc(...)
   ...
 end
 ...
end;



Страницы: 1 вся ветка

Текущий архив: 2010.08.27;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.047 c
15-1274862762
ocean
2010-05-26 12:32
2010.08.27
Печать картинок


2-1275731745
REX
2010-06-05 13:55
2010.08.27
Смена рабочего файла БД


2-1270195945
Lowlander
2010-04-02 12:12
2010.08.27
Маска ввода email


2-1265350338
Mery
2010-02-05 09:12
2010.08.27
сворачивание программы на панель задач


15-1275368289
user123
2010-06-01 08:58
2010.08.27
Два интересующих меня вопроса о копировании и видеопотоке