我正在阅读某些书,但遇到了一段代码,书中未作解释,但其中的一部分对我来说非常令人困惑,粗体部分,我想知道它的含义。

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设置s1s2。似乎代码建议对数组(实现集)进行排序。
代码在s1.arrayAs2.arrayA上移动,如果两个集合中都存在某个元素,则它将该元素放置在s.arrayA中。

09-06 17:46