删除升序数组中的重复元素,begin到end之间的代码是什么意思呢?求详细解释

问题遇到的现象和发生背景
问题相关代码,请勿粘贴截图
运行结果及报错内容
我的解答思路和尝试过的方法
我想要达到的结果

//删除升序数组中的重复元素(指针版)
//编写程序,删除一维数组中所有相同的数,只保留一个,
//数组中的数已按由小到大的顺序排列,
//int unique(int *pArr,int num)
//pArr和num分别为数组首地址和数组元素的个数,
//函数返回删除重复元素之后数组中元素个数。
#include <fstream>
#include <iostream>
using namespace std;
int unique(int *pArr,int num)
{
/********************************** Begin ****************************/
    int *p,count;
    p=pArr;
    for(int i=0;i<num-1;i++)
    {
        if(pArr[i+1]!=pArr[i])
        {
            p++;
            *p=pArr[i+1];
        }
    }
    count=p-pArr+1;
    return count;






/********************************** End ******************************/
}
int main()
{
    ofstream file_out("out.txt"); 
    if(!file_out) return -1;
    streambuf *std_out;
    std_out= cout.rdbuf(file_out.rdbuf());  
    int a[]={2,2,2,3,4,4,5,6,6,6,6,7,7,8,9,9,10,10,10};
    int num1 = sizeof(a)/sizeof(int);
    int num2 = unique(a,num1);
    cout<<a[0];
    for (int i=1;i<num2;i++)
    {
        cout<<" "<<a[i];
    }
    cout<<'\n';
    file_out.close();
    cout.rdbuf(std_out);    
    return 0;
}

它使用的快慢指针法,快指针是由i确定,慢指针是p,当执行到16行的时候,发现下一个元素和快指针的元素不同是,p移向p的下个元素,并把那个不同的复制过来
如果快指针指向的元素和快指针指向的下一个元素相同,只移动快指针而不移动慢指针p