我在编写一个返回1s和0s而不是true或false的代码。但这似乎并不正确。运算符重载(int as bool)
int Short_Vector::operator==(const Short_Vector& obj){
if(a == obj.a && b == obj.b && c == obj.c && d == obj.d){
return 1;
}else{
return 0;
}
}
所以它应该为每个变量返回一个值。
我也试过这样:
int Short_Vector::operator==(const Short_Vector& obj){
int a_tf, b_tf, c_tf, d_tf;
if(a == obj.a){
a_tf = 1;
}else{
a_tf = 0;
}
if(b == obj.b){
b_tf = 1;
}else{
b_tf = 0;
}
if(c == obj.c){
c_tf = 1;
}else{
c_tf = 0;
}
if(d == obj.d){
d_tf = 1;
}else{
d_tf = 0;
}
return(a_tf, b_tf, c_tf, d_tf)
}
但我得到的逗号是操作错误。
EDIT
获取错误:错误:从 'INT' 转换到非标量类型“Short_Vector。
我试图表示一个看起来像这样的矢量[9,1,5,5]。
然后我会说
`Short_Vector a(2, 6, 9, 4);
Short_Vector b(3, 8, 7, 6);
Short_Vector c = a == b;
cout<<c;`
输出则是:[0,0,0,0]
究竟是你想回来吗?四位表示?数字1100或类似?四个单独的值? – chris 2013-05-09 19:19:55
第一个代码实际上应该工作。它做错了什么? – 0x499602D2 2013-05-09 19:21:57
@ 0x499602D2,OP想要返回值中的四件事情(或者至少这是我从中间语句中得到的印象)。 – chris 2013-05-09 19:23:31