题解 | #数组元素处理#

数组元素处理

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

采用双循环,当数组中元素为0时,后面的所有的值便前移一位,再从该元素之后再次寻找0元素,执行同样的操作。

#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......
for(int i=0;i<n;i++)
{
    if(*(p+i)==0)
        {
            for(int j=i;j<n;j++)
            {*(p+j)=*(p+j+1);}
        }
}
}
全部评论

相关推荐

猿辅导 Java后端日常实习 800一天
点赞 评论 收藏
转发
点赞 收藏 评论
分享
牛客网
牛客企业服务