我是一名新的c ++用户,并编写了一个与其他功能一起使用的代码。我需要使用if& amp;修改代码。否则if语句导致整个代码耗时4.6333分钟,相比之下修改前的0.61分钟(注意这些持续时间是针对整个代码而不是我下面粘贴的例子)。
下面是“仅”修改部分作为示例(可以单独使用c ++运行)。
任何人都有任何建议让这段代码更快?
#include <iostream>
#include <vector>
#include <fstream>
#include <ctime>
using namespace std;
int main()
{
static const double InflVecVals001[9] = { 100.0, 200.0, 300.0, 400.0, 500.0, 600.0, 700.0, 800.0, 900.0 };
int FloorMnodeTagscol1[6] = { 11, 12, 13, 14, 15, 16 }; int FloorMnodeTagscol6[6] = { 61, 62, 63, 64, 65, 66 };
int FloorMnodeTagscol2[6] = { 21, 22, 23, 24, 25, 26 }; int FloorMnodeTagscol7[6] = { 71, 72, 73, 74, 75, 76 };
int FloorMnodeTagscol3[6] = { 31, 32, 33, 34, 35, 36 }; int FloorMnodeTagscol8[6] = { 81, 82, 83, 84, 85, 86 };
int FloorMnodeTagscol4[6] = { 41, 42, 43, 44, 45, 46 }; int FloorMnodeTagscol9[6] = { 91, 92, 93, 94, 95, 96 };
int FloorMnodeTagscol5[6] = { 51, 52, 53, 54, 55, 56 };
int tagNode = 91;
double fact;
if ((tagNode == FloorMnodeTagscol1[0]) || (tagNode == FloorMnodeTagscol1[1]) || (tagNode == FloorMnodeTagscol1[2]) || (tagNode == FloorMnodeTagscol1[3]) || (tagNode == FloorMnodeTagscol1[4]) || (tagNode == FloorMnodeTagscol1[5]))
{
fact = InflVecVals001[0];
}
else if ((tagNode == FloorMnodeTagscol2[0]) || (tagNode == FloorMnodeTagscol2[1]) || (tagNode == FloorMnodeTagscol2[2]) || (tagNode == FloorMnodeTagscol2[3]) || (tagNode == FloorMnodeTagscol2[4]) || (tagNode == FloorMnodeTagscol2[5]))
{
fact = InflVecVals001[1];
}
else if ((tagNode == FloorMnodeTagscol3[0]) || (tagNode == FloorMnodeTagscol3[1]) || (tagNode == FloorMnodeTagscol3[2]) || (tagNode == FloorMnodeTagscol3[3]) || (tagNode == FloorMnodeTagscol3[4]) || (tagNode == FloorMnodeTagscol3[5]))
{
fact = InflVecVals001[2];
}
else if ((tagNode == FloorMnodeTagscol4[0]) || (tagNode == FloorMnodeTagscol4[1]) || (tagNode == FloorMnodeTagscol4[2]) || (tagNode == FloorMnodeTagscol4[3]) || (tagNode == FloorMnodeTagscol4[4]) || (tagNode == FloorMnodeTagscol4[5]))
{
fact = InflVecVals001[3];
}
else if ((tagNode == FloorMnodeTagscol5[0]) || (tagNode == FloorMnodeTagscol5[1]) || (tagNode == FloorMnodeTagscol5[2]) || (tagNode == FloorMnodeTagscol5[3]) || (tagNode == FloorMnodeTagscol5[4]) || (tagNode == FloorMnodeTagscol5[5]))
{
fact = InflVecVals001[4];
}
else if ((tagNode == FloorMnodeTagscol6[0]) || (tagNode == FloorMnodeTagscol6[1]) || (tagNode == FloorMnodeTagscol6[2]) || (tagNode == FloorMnodeTagscol6[3]) || (tagNode == FloorMnodeTagscol6[4]) || (tagNode == FloorMnodeTagscol6[5]))
{
fact = InflVecVals001[5];
}
else if ((tagNode == FloorMnodeTagscol7[0]) || (tagNode == FloorMnodeTagscol7[1]) || (tagNode == FloorMnodeTagscol7[2]) || (tagNode == FloorMnodeTagscol7[3]) || (tagNode == FloorMnodeTagscol7[4]) || (tagNode == FloorMnodeTagscol7[5]))
{
fact = InflVecVals001[6];
}
else if ((tagNode == FloorMnodeTagscol8[0]) || (tagNode == FloorMnodeTagscol8[1]) || (tagNode == FloorMnodeTagscol8[2]) || (tagNode == FloorMnodeTagscol8[3]) || (tagNode == FloorMnodeTagscol8[4]) || (tagNode == FloorMnodeTagscol8[5]))
{
fact = InflVecVals001[7];
}
else if ((tagNode == FloorMnodeTagscol9[0]) || (tagNode == FloorMnodeTagscol9[1]) || (tagNode == FloorMnodeTagscol9[2]) || (tagNode == FloorMnodeTagscol9[3]) || (tagNode == FloorMnodeTagscol9[4]) || (tagNode == FloorMnodeTagscol9[5]))
{
fact = InflVecVals001[8];
}
else
{
fact = 1.0;
}
//cout << "\n tagnode:" << tagNode << endl;
//cout << "\n factor:" << fact << endl;
cin.get();
return 0;
}
答案 0 :(得分:0)
使用示例代码,您可以简单地
if ((tagNode - 1) % 10 < 6 && 11 <= tagNode && tagNode <= 96) {
fact = (tagNode / 10) * 100.;
} else {
fact = 1.;
}
但是假设值不是简单范围,如示例所示,并且您必须多次执行映射,您可能会执行以下操作:
static const std::map<int, double> m = {
{ 11, 100.}, {12, 100.}, {13, 100.}, {14, 100.}, {15, 100.}, {16, 100.},
{ 21, 200.}, {22, 200.}, {23, 200.}, {24, 200.}, {25, 200.}, {26, 200.},
{ 31, 300.}, {32, 300.}, {33, 300.}, {34, 300.}, {35, 300.}, {36, 300.},
{ 41, 400.}, {42, 400.}, {43, 400.}, {44, 400.}, {45, 400.}, {46, 400.},
{ 51, 500.}, {52, 500.}, {53, 500.}, {54, 500.}, {55, 500.}, {56, 500.},
{ 61, 600.}, {62, 600.}, {63, 600.}, {64, 600.}, {65, 600.}, {66, 600.},
{ 71, 700.}, {72, 700.}, {73, 700.}, {74, 700.}, {75, 700.}, {76, 700.},
{ 81, 800.}, {82, 800.}, {83, 800.}, {84, 800.}, {85, 800.}, {86, 800.},
{ 91, 900.}, {92, 900.}, {93, 900.}, {94, 900.}, {95, 900.}, {96, 900.}
};
auto it = m.find(tagNode);
fact = ((it != m.end()) ? it-> second : 1.);
哪个有
N log N
用于地图构建(完成一次)。log(N)
搜索的复杂性。而不是线性搜索。