leetcode283移动零问题(依旧暴力解法,现在在看leetcode别人更好的解法,感觉别人好厉害)

本文讨论了一个名为`moveZeroes`的函数,用于将给定数组`nums`中的非零元素移动到前面,零元素填充在后面。作者随后提出了一种简化版本,询问是否有更优的实现方法。
摘要由CSDN通过智能技术生成

我的代码:把不是零的数装到数组a中;再重新给nums赋值,把零放在后面;

void moveZeroes(int* nums, int numsSize) {

    int i=0,c=0;int a[numsSize];

    for(i=0;i<numsSize;i++){

        if(nums[i]!=0){

            a[c++]=nums[i];

        }

    }

    for(i=0;i<c;i++){

        nums[i]=a[i];

    }

    for(i=c;i<numsSize;i++){

        nums[i]=0;

    }

    for(i=0;i<numsSize;i++){

        printf("%d",nums[i]);

    }

}

运行结果:

更改一点后:(直接把非零的数重新给nums赋值,后面补零)(你们还有更好的改进吗)

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值