嵌套逻辑&&允许操作员?

时间:2011-06-04 20:43:08

标签: c++ octave

我已经编写了一个用于Octave的.oct函数,它没有给出我预期的结果,我认为问题可能在于下面给出的代码片段 - 是否可以嵌套逻辑&&我已经完成了运算符,还是需要使用更多内部if循环分离出来?

 if ((( final_side_PDF > final_uwr_PDF && final_side_PDF > final_unr_PDF ) && final_side_PDF > final_dwr_PDF ) && final_side_PDF > final_dnr_PDF)
    {
    market_model(ii) = 0.0;
    }
 else if ((( final_uwr_PDF > final_side_PDF && final_uwr_PDF > final_unr_PDF ) && final_uwr_PDF > final_dwr_PDF ) && final_uwr_PDF > final_dnr_PDF )
    {
    market_model(ii) = 1.0;
    }
 else if ((( final_unr_PDF > final_side_PDF && final_unr_PDF > final_uwr_PDF ) && final_unr_PDF > final_dwr_PDF ) && final_unr_PDF > final_dnr_PDF)
    {
    market_model(ii) = 2.0;
    }
 else if ((( final_dwr_PDF > final_side_PDF && final_dwr_PDF > final_uwr_PDF ) && final_dwr_PDF > final_unr_PDF ) && final_dwr_PDF > final_dnr_PDF)
    {
    market_model(ii) = -1.0;
    }
 else if ((( final_dnr_PDF > final_side_PDF && final_dnr_PDF > final_uwr_PDF ) && final_dnr_PDF > final_unr_PDF ) && final_dnr_PDF > final_dwr_PDF)
    {
    market_model(ii) = -2.0;
    }
 else
    {
    market_model(ii) = market_model(ii-1);
    }

编辑以回应评论

我希望检查五个变量中的哪一个; final_side_PDF,final_uwr_PDF,final_unr_PDF,final_dwr_PDF和final_dnr_PDF;具有最大值并返回唯一的识别号码; 0,1,2,-1,-2;取决于哪一个是最大值。上面的代码包含在主(ii)循环中。

1 个答案:

答案 0 :(得分:2)

建议:

 typedef int final_t;

 // From your code I assume that "final_xx" can have the same values, otherwise a std::map would be simpler. 
 std::multimap<final_t, double> finals;

 finals.insert(std::make_pair(final_side_PDF, 0.0));
 finals.insert(std::make_pair(final_uwr_PDF,  1.0));
 finals.insert(std::make_pair(final_unr_PDF,  2.0));
 finals.insert(std::make_pair(final_dwr_PDF, -1.0));
 finals.insert(std::make_pair(final_dnr_PDF, -2.0));

 auto max_final = finals.rbegin();

 if(finals.count(max_final->first) == 1)
    masket_model(ii) = max_final->second;
 else
    market_model(ii) = market_model(ii-1);

如果“final_xx”都具有唯一值,则可以使其更简单:

 typedef int final_t;

 std::map<final_t, double> finals;

 finals[final_side_PDF] =  0.0;
 finals[final_uwr_PDF]  =  1.0;
 finals[final_unr_PDF]  =  2.0;
 finals[final_dwr_PDF]  = -1.0;
 finals[final_dnr_PDF]  = -2.0;

 auto max_final = finals.rbegin();

 market_model(ii) = max_final->second;