在阅读此问题之前,请注意这是hp代码大战(编程竞赛)的 PRACTICE 问题,我不是在问论坛有关真正的问题。我的程序应该采取以下输入:
示例:
输出应该是猜测最接近的人的姓名
示例:
我目前正在编写函数,该函数返回与猜测最接近的数字。但是,当我运行代码时,它在两行上给出了错误no match for call '(std::vector<int>) (int)
。发送错误的行在我的代码中的注释中指出。
这是我的代码:
vector<int> compare(vector<int> nums, int loopnum, int ans){
vector<int> buff2;
for (int i = 0; i<loopnum;i++){
vector<int>diff;
int buff = ans - nums.at(i);
for (int j = 0; j<loopnum; j++){
diff.push_back(buff);
for (int k = 0; k<diff.size(); k++){
if (k == 0){
buff2.push_back(diff.at(k));
}
else{
// this line is sending back an error
if ((abs(buff2(0))) > abs(diff.at(k))) {
buff2.clear();
buff2.push_back(diff.at(k));
}
// this line is also sending back an error
else if ((abs(buff2(0))) == abs(diff.at(k))){
buff2.push_back(diff.at(k));
}
}
}
}
}
return buff2;
}
请帮我解决这个问题!
答案 0 :(得分:7)
buff2(0)
应为buff2[0]
或buff2.at(0)