2012-12-04 20 views
0

我得到一个奇怪的错误,当我尝试编译如下:为什么不编译?敌不过“运营商=”

class CucumberMarket { 
public: 
    bool ans; 
    int n,cont,K,b; 
    bool check(const vector<int> &precios,long long price,int pos) { 
    ++cont; 
    if(cont == K and b < price) ans = false; 
    if(!ans) return ans; 
    for(int i = pos + 1; i < n; ++i) { 
     if(cont < K) ans &= check(precios,price + precios[i],i); 
    } 
    --cont; 
    } 
    string check(vector <int> price, int budget, int k) { 
    n = price.size(); 
    K = k; 
    b = budget; 
    ans = true; 
    cont = 0; 
    for(int i = 0; i < n and ans; ++i) ans &= (this -> check(price,price[i],i)); 
    return ans ? "YES" : "NO"; 
    } 
}; 

这就是我得到:

C:\Users\Usuario\Desktop\Temp\C++\tc.cpp: In member function `std::string CucumberMarket::check(std::vector<int, std::allocator<int> >, int, int)': 
C:\Users\Usuario\Desktop\Temp\C++\tc.cpp:24: error: no match for 'operator&=' in '((CucumberMarket*)this)->CucumberMarket::ans &= CucumberMarket::check(std::vector<int, std::allocator<int> >, int, int)(vector<int,std::allocator<int> >(((const std::vector<int, std::allocator<int> >&)((const std::vector<int, std::allocator<int> >*)(&price)))), (&price)->std::vector<_Tp, _Alloc>::operator[] [with _Tp = int, _Alloc = std::allocator<int>](((unsigned int)i)), i)' 
[Finished in 0.2s with exit code 1] 

第24行是这样的:

for(int i = 0; i < n and ans; ++i) ans &= (this -> check(price,price[i],i)); 

我不明白,为什么我得到这个?我以前做过这个,它总是编译

+2

右边的布尔表达式我打赌它调用第二个重载,它返回一个字符串。 – chris

回答

7

std::string CucumberMarket::check它似乎是在假设检查返回string。这是你的问题,你期望它会返回一个bool
如果你想让它正常工作,最简单的解决将是迫使投price[i]long long如下

for(int i = 0; i < n and ans; ++i) ans &= (this -> check(price,(long long)price[i],i));

我建议你重载不如此聪明并拢签名。

+0

谢谢,我刚才犯的最愚蠢的错误。 – hinafu

+0

欢迎您! –

2

看看你的错误信息:它试图

ans &= check(..., int, int) 

,并检查该版本返回一个字符串。你需要在&=