Главная страница
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.23 c
4-1172734473
Darth Avenger
2007-03-01 10:34
2010.08.27
Купюроприемник CashCode, протокол ccnet


3-1239426880
Роман
2009-04-11 09:14
2010.08.27
визуализация данных БД


15-1274819385
Юрий
2010-05-26 00:29
2010.08.27
С днем рождения ! 26 мая 2010 среда


2-1265978961
pavelkq
2010-02-12 15:49
2010.08.27
Поразрядная сортировка списка слов


15-1270016502
Alkid
2010-03-31 10:21
2010.08.27
Тонкий стёб над С++