题解 | #数组元素处理#

数组元素处理

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
来这里练算法,就知道复制运行,注释都不会去掉
点赞 回复 分享
发布于 2024-02-21 21:04 广东
我求求你们了,好好看看算法行不行,我明明写了注释的
点赞 回复 分享
发布于 2024-02-21 21:04 广东
这个代码连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; } } }
点赞 回复 分享
发布于 2024-02-21 15:36 浙江

相关推荐

明天不下雨了_人机版:让我们大声的说出来:以前的未来就是现在
点赞 评论 收藏
分享
牛客383479252号:9,2学生暑期实习失利开始投小厂,给这群人整自信了
点赞 评论 收藏
分享
评论
21
3
分享

创作者周榜

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