0

我正在使用 cplex 用 C++ 编写程序。我能够从一个文件中读取信息,这样我就可以创建一个包含百分比的矩阵和两个包含卖价和买价的数组。:

double ** percents;
double * prices;
double * sellprices;
prices = (double *)malloc(n*sizeof(double ));
sellprices = (double *)malloc(n*sizeof(double ));
percents = (double **)malloc(n*sizeof(double *));
for(i=0; i < n; i++) 
    percents[i] = (double *)malloc(m*sizeof(double));

此外,我创建了两个最终应该优化的数组。

IloNumVarArray X(env);
IloNumVarArray Y(env);

for (int i=0;i<2;i++)
        X.add(IloNumVar(env));
for (int i=0;i<n;i++)
        Y.add(IloNumVar(env));

model.add(IloMaximize(env, sellprices[i]*X[i] - prices[i]*Y[i]));

这是创建目标的正确方法吗?

4

1 回答 1

3

你需要计算

sum_i sellprices[i] * X[i]

   sum_i prices[i] * Y[i]

如果您希望价格和销售价格是普通的 c 数组,则需要 IloExpr

IloExpr totalSales(env);
IloExpr costOfGoodsSold(env);
for (int i = 0; i < n; ++i) {
   totalSales += sellprices[i]*X[i];
   costOfGoodsSold += prices[i]*Y[i];
}
model.add(IloMaximize(env, totalSales - costOfGoodsSold));

现在,您可以通过将 IloNumArrays 用于销售价格和价格来避免 malloc 和循环

sellprices = IloNumArray(env, n);
prices = IloNumArray(env, n);
model.add(IloMaximize(env, IloScalProd(sellPrices, X) - IloScalProd(prices, Y)));

如果您不想使用 IloNumArray,您至少应该尝试 std::vector。

于 2012-05-06T04:31:49.043 回答