本文介绍: 由于 dest 指针要指向最后一个非 0 数据,所以 dest 首先要 ++,为该非 0 数据提供一个空位,此时 dest 指针指向的是 0 数据,cur 指针指向的是非 0 的数据,于是将 cur 和 dest 指针指向的数据进行交换。我们让 cur 指针(并不是真的指针,方便理解才这样说)指向下标 0,用来遍历数组,dest 指针指向下标 -1 ,因为 dest 指针的含义是指向最后一个非 0 数据,而现在 cur 指针还没有遍历到非 0 数据,所以先指向 -1。我们得到关系,当 nums[cur]!
代码:
题解:
根据题意,我们要将数组进行处理,分为 非0 的区间和 全为0 的区间
现在我们通过 cur 指针遍历数组并按相关规则对数据进行处理,遍历过的区间是 已处理 区间,还未遍历的区间是未处理区间,而 已处理 区间中又分为 非0 的区间和 全为0 的区间,我们设定 dest 指针指向最后一个非0数据
这样划分,当 cur 指针遍历完数组以后,数组就被 dest 指针划分成了题意中左边为非 0 元素,右边为 0 的结构
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。