题解 | #数组元素处理#

数组元素处理

http://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 *q=p;
    int cnt=0;
    for(int i=0;i<n;i++){
        if(*p!=0){
            *q=*p;
            q++;
            cnt++;
        }
        p++;
    }
    for(int i=cnt;i<n;i++){
        *q=0;
        q++;
    }
}
全部评论
*q=p; *q=*p;不太理解可以讲一下吗(第一句是p指向了arr首地址,q指向了arr首元素吗)
点赞 回复 分享
发布于 2022-03-26 21:27

相关推荐

这是什么操作什么意思,这公司我服了...
斯派克spark:意思是有比你更便宜的牛马了
点赞 评论 收藏
分享
认真搞学习:28小登的建议,投算法岗不要写什么物理竞赛,互联网+,多写点项目,用什么算法做了什么。还有本科算法是不可能的开发你这个也没有项目啊
点赞 评论 收藏
分享
白火同学:能。我当初应届沟通了1200,收简历50,面试10左右吧,加油投吧
投了多少份简历才上岸
点赞 评论 收藏
分享
评论
14
1
分享

创作者周榜

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