题解 | #数组元素处理#

数组元素处理

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

没有用到双指针,也没有其他题解的图 思维也很简单,适合小白理解

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-1; j++)
                p[j] = p[j+1];//把字符往前移动
            p[n-1] = 0;//将最后一个设置为0
            n--;//缩短数组遍历长度
            /*感谢大神的意见,对于多个0可加上如下注释代码*/
            //if(p[i]==0)
            //{
            //	i--;
            //}
        }
    }

}
全部评论
你这个没考虑连续两个零的情况吧?
2 回复 分享
发布于 2022-04-02 12:02
之前写了个多余的变量,已删,有什么问题欢迎回复
1 回复 分享
发布于 2022-02-13 17:02
连着两个0不行的
2 回复 分享
发布于 2023-03-07 14:32 广东
有大神能分析下复杂度吗?
1 回复 分享
发布于 2022-03-19 13:58
这个代码连0测试不过。我写了一个,但是复杂度不好 void func(int* p, int n) { // write your code here...... int zeroIdx = 0; int zeroCnt = 0; while (1) { bool findFlag = false; for(int i = zeroIdx; i < n - zeroCnt; i++){ if (p[i] == 0) { zeroCnt++; zeroIdx = i; for (int j = i; j < n - zeroCnt; j++) { p[j] = p[j + 1]; } p[n - zeroCnt] = 0; findFlag = true; break; } } if (!findFlag) { break; } } }
点赞 回复 分享
发布于 02-21 15:36 浙江
我求求你们了,好好看看算法行不行,我明明写了注释的
点赞 回复 分享
发布于 02-21 21:04 广东
来这里练算法,就知道复制运行,注释都不会去掉
点赞 回复 分享
发布于 02-21 21:04 广东

相关推荐

11-15 17:19
湖南大学 Java
成果成果成果果:这是哪个公司的hr,这么离谱吗,我没见过用性别卡技术岗的,身边女性同学拿大厂offer的比比皆是
点赞 评论 收藏
分享
我是小红是我:学校换成中南
点赞 评论 收藏
分享
评论
21
3
分享
牛客网
牛客企业服务