本文整理汇总了C++中strvec::size方法的典型用法代码示例。如果您正苦于以下问题:C++ strvec::size方法的具体用法?C++ strvec::size怎么用?C++ strvec::size使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类strvec
的用法示例。
在下文中一共展示了strvec::size方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: achievable_from
void Matrix::achievable_from(strvec &nodes, strvec from) const{
int was = nodes.size();
involved_with(nodes, from);
if (nodes.size() == was)
return;
achievable_from(nodes, nodes);
}
示例2: processParallelFor
//Returns true if it processes something
//Returns false if it never finds a parallel for
bool processParallelFor()
{
bool foundPragma = false;
for (int i = 0; i < input.size(); i++)
{
std::string curStr = input.at(i);
if (curStr.substr(0, 24).compare("#pragma omp parallel for") == 0 ||
curStr.substr(0, 15).compare("#pragma omp for") == 0)
{
foundPragma = true;
int j = i + 2; //move up to pragma and pass the for loop
if (input.at(j).substr(0,1).compare("{") == 0) //if the for is contained in brackets. weird case also where trim did not remove tab after bracket
{
int brackets = 1;
//find the end of the parallel region
while (j < input.size())
{
j++;
std::string tempStr = input.at(j);
if (tempStr.length() <= 0)
{
continue;
}
if (tempStr.at(0) == '{')
{
brackets++;
}
if (tempStr.at(0) == '}')
{
brackets--;
}
if (brackets == 0)
{
break;
}
}
}
else //if there are no brackets, then j is pointing to the contents of the for loop
{
i += 2;
j += 2;
input.insert(input.begin() + i, "{");
input.insert(input.begin() + j, "}");
i -= 2; //move i back to the pragma
}
//at this point, j points to the ending bracket, and i points to the pragma
parallelForHelper(i, j);
}
//otherwise, move on--handle it elsewhere
}
return foundPragma;
}
示例3: get_int_names
strvec MtxLP::get_int_names(strvec names){
strvec rv(names.size());
strvec::iterator it = names.begin(), it2 = rv.begin();
while (it != names.end())
*it2++ = get_int_name(*it++);
return rv;
}
示例4: add
//Simple vector move function, pushes from from to to
void add(strvec& from, strvec& to)
{
for (int i = 0; i < from.size(); i++)
{
to.push_back(from.at(i));
}
}
示例5: redeclareVars
//Redeclares the vars in varlist by pushing them to outlist
//Note: Array types make this function confusing. If a variable is declared as int b[5], its entry in the varList will just be "b"
//All variables should be in the hashmap, so if we don't find "b", assume we're looking for "b["
void redeclareVars(strvec& varList, strvec& outList)
{
for (int i = 0; i < varList.size(); i++)
{
std::string typeStr;
std::string newLine;
if (varsAndTypes.find(varList.at(i)) == varsAndTypes.end()) //if the var not there, should be array type
{
std::string varNameStr = varList.at(i);
varNameStr = varNameStr.append("["); //add this to look for array types
for (std::map<std::string, std::string>::iterator it = varsAndTypes.begin(); it != varsAndTypes.end(); it++)
{
if (it->first.substr(0, varNameStr.length()).compare(varNameStr) == 0) //if varnamestr is b[ and the entry in the map starts with b[, we've found it
{
//we want to declare it as int b[5], so we still need the type
typeStr = it->second;
std::string varNameStr = it->first;
newLine = typeStr.append(" ").append(varNameStr).append(";");
}
}
}
else //if it's in there, append like always
{
typeStr = varsAndTypes[varList.at(i)];
newLine = typeStr.append(" ").append(varList.at(i)).append(";");
}
outList.push_back(newLine);
}
}
示例6: del_cols
void Matrix::del_cols(strvec &names){
for (strvec::iterator it = names.begin(); it != names.end(); ++it){
del(*it);
std::remove(cols.begin(), cols.end(), *it);
}
cols.resize(cols.size() - names.size());
}
示例7: printVector
//Just outputs vecRef
void printVector(strvec& vecRef)
{
for (int i = 0; i < vecRef.size(); i++)
{
std::cout << vecRef.at(i) << std::endl;
}
}
示例8: optimiseLen
void MtxLP::optimiseLen(bool max, strvec q, bool presolve){
if (q.empty())
q = getColNames();
setObjDir(max);
setLenObjective(q, true);
Solve(presolve);
cleanTmpRows(q.size());
}
示例9: processCritical
//Returns true if it processes something
//Returns false if it never finds a critical
bool processCritical()
{
bool foundPragma = false;
for (int i = 0; i < input.size(); i++)
{
std::string curStr = input.at(i);
if (curStr.substr(0, 20).compare("#pragma omp critical") == 0)
{
foundPragma = true;
int j = i + 2; //move past the opening bracket
int brackets = 1; //OK to assume we have an opening bracket
//find the end of the parallel region
while (j < input.size())
{
j++;
std::string tempStr = input.at(j);
if (tempStr.length() <= 0)
{
continue;
}
if (tempStr.at(0) == '{')
{
brackets++;
}
if (tempStr.at(0) == '}')
{
brackets--;
}
if (brackets == 0)
{
break;
}
}
//at this point, j points to the ending bracket, and i points to the pragma
criticalHelper(i, j);
}
//otherwise, move on--handle it elsewhere
}
return foundPragma;
}
示例10: declarePrivatesInMain
//Declares the varlist in the main function
void declarePrivatesInMain(strvec& varList)
{
int mainLine = 0;
for (mainLine; mainLine < input.size(); mainLine++)
{
std::string curStr = input.at(mainLine);
if (curStr.compare("int main()") == 0)
{
break;
}
}
mainLine += 2; //move past brackets
for (int i = 0; i < varList.size(); i++)
{
input.insert(input.begin() + mainLine++, varList.at(i));
}
}
示例11: processVariables
//Iterates through the whole program looking for variable declarations
//Supports ONLY int and double declarations
//NOTE: This DELETES all declarations (converts the line to ""), since they are added in appropriate locations later
void processVariables()
{
const std::string intStr = "int";
const std::string doubleStr = "double";
for (int i = 0; i < input.size(); i++)
{
std::string curStr = input.at(i);
std::string typeStr;
int offset;
//determine what is being declared
if (curStr.substr(0, 3).compare("int") == 0) //integer declaration
{
if (curStr.substr(0, 8).compare("int main") == 0) //special case for this int!
{
continue;
}
typeStr = intStr;
offset = 4;
}
else if (curStr.substr(0, 6).compare("double") == 0) //double declaration
{
typeStr = doubleStr;
offset = 7;
}
else //TODO could include more primitives here
{
continue; //not a var declaration
}
//everything below here applies only to var declarations, since we continued above
if (curStr.find(",") == std::string::npos) //if no commas
{
std::string varName = curStr.substr(offset, (curStr.length() - offset - 1)); //-1 to leave semicolon off
varsAndTypes[varName] = typeStr;
varsAndLines[varName] = i;
}
else //multiple vars/line
{
std::istringstream buf(curStr);
std::istream_iterator<std::string> beg(buf), end;
std::vector<std::string> tokens(beg, end);
for (int j = 1; j < tokens.size(); j++)
{
std::string varName = tokens.at(j).substr(0, tokens.at(j).length() - 1); //leave off the comma or semicolon
varsAndTypes[varName] = typeStr;
varsAndLines[varName] = i;
}
}
//now that the value is preserved in the hashmap, remove the declaration
input.at(i) = "";
}
}
示例12: insertAfterIncludes
//Pushes the vecRef into input after the include statements (at the top)
void insertAfterIncludes(strvec& vecRef)
{
//move past any includes
int i;
for (i = 0; i < input.size(); i++)
{
if (input.at(i).length() > 0 && input.at(i).at(0) != '#')
{
break;
}
}
//once we're here, we're past the includes and we can copy the new function
//we need to insert this in reverse order
for (int j = vecRef.size()-1; j >= 0; j--)
{
input.insert(input.begin() + i, vecRef.at(j));
}
}
示例13: processGetThreadNum
//Iterates through the whole program looking for omp_get_thread_num calls
//Replaces them with a call to the paramStruct
void processGetThreadNum()
{
std::string replacement = "id = ((StartEnd*) paramStruct)->threadNum;";
for (int i = 0; i < input.size(); i++)
{
std::string curStr = input.at(i);
std::size_t pos = curStr.find("omp_get");
if (pos != std::string::npos) //if we find one
{
//replace with a call to gettid()
input.at(i) = replacement;
}
}
}
示例14: ko
void MtxLP::ko(OBJSTAT& rv, stomap* obj, strvec blockvec, bool max, bool presolve){
block(&blockvec, true);
getOptObjStat(rv, obj, max, presolve);
cleanTmpRows(blockvec.size());
}
示例15: isCutSet
bool MtxLP::isCutSet(stomap* obj, strvec set, bool max, bool presolve){
block(&set, true);
optimise(obj, max, presolve);
cleanTmpRows(set.size());
return is_zero(getObjValue());
}