我正在阅读某些书,但遇到了一段代码,书中未作解释,但其中的一部分对我来说非常令人困惑,粗体部分,我想知道它的含义。
void Set::intersection(const Set& s1, const Set& s2)
{
Set s;
s.arrayA = new double[ s1.sizeA<s2.sizeA ? s1.sizeA : s2.sizeA];
int i, j, k;
while(i < s1.sizeA && j < s2.sizeA)
if(s1.arrayA[i] < s2.arrayA[j])
i++;
else if (s1.arrayA[i] > s2.arrayA[j])
j++;
else
s.arrayA[k++] = s1.arrayA[j++,i++]; // question is about this line
s.sizeA= k;
deleteA();
copyA(s);
}
它是做什么的,为什么[]中有两个参数?提前致谢。
最佳答案
方括号内的两个参数是使用comma operator的表达式。这样的表达式的结果是最后一项的结果(j++, i++
给i加1,而j也加1)。
因此s.arrayA[i++] = s1.arrayA[j++,i++];
确实可以转换为相等的j++, s.arrayA[i++] = s1.arrayA[i++];
此代码intersects设置s1
和s2
。似乎代码建议对数组(实现集)进行排序。
代码在s1.arrayA
和s2.arrayA
上移动,如果两个集合中都存在某个元素,则它将该元素放置在s.arrayA
中。