3

在阅读这个问题之前,请注意这是 hp codewars(编程竞赛)的一个PRACTICE问题,我并不是在向论坛询问一个真正的问题。我的程序应该接受以下输入:

  • 一个代表罐子里糖果数量的数字
  • 用户将输入的猜测次数
  • 一个人的名字,后跟一个空格,然后是他们的猜测

例子:

  • 422:罐子里糖果的数量
  • 2:猜测次数
  • 乔 324:猜者的名字和他们猜罐子里有多少糖果
  • Mary 435:第二次猜测和猜测

输出应该是最接近猜测的人的名字

例子:

  • 玛丽

我目前正在编码返回最接近猜测的数字的函数。但是,当我运行代码时,它给了我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;
}

请帮我解决这个问题!

4

1 回答 1

8

buff2(0)应该是buff2[0]buff2.at(0)

于 2015-03-07T23:08:36.293 回答