题解 | #数组元素处理#

数组元素处理

https://www.nowcoder.com/practice/bb840c11be674d01b582847a6921d384

#include <iostream>
using namespace std;

void func(int* p, int n);

int main() {

    int arr[6] = { 0 };
    for (int i = 0; i < 6; i++) {
        cin >> arr[i];
    }

    func(arr, 6);

    for (int i = 0; i < 6; i++) {
        if (i == 5) {
            cout << arr[i] << endl;
        }
        else {
            cout << arr[i] << " ";
        }
    }

    return 0;
}

void func(int* p, int n) {

    // write your code here......
    int count_0=0;//记录0的个数
    for (int i=0;i<n;i++)
    {
        if (p[i]==0 & (n-count_0-1>i))//(n-count_0-1>i)说明还有位置需要前移
        {
            ++count_0;//增加一个0的个数
            for(int j=i;j<n-count_0;j++)//将从i开始的数字前移
            {
                p[j]=p[j+1];
            }
            p[n-count_0]=0;//同时将对应后面的位置置0
        }
    }
    

}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-09 12:02
ssob上原来真有BOSS啊
硫蛋蛋:这种也是打工的,只不是是给写字楼房东打工
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务