• 力扣:1089. 复写零


    今日分享一道力扣经典题目,复写0!

    题目如下:

    题目分析:

    题目要求是进行复写0,而且不能超过原数组长度,且只能在原地进行操作!

    解决本题最好的方法就是进行双指针方法!

    算法分析

    一、双指针算法找到最后一个要复写的数

    二、然后从后向前进行完成复写(因为如果要是从前向后进行复写会导致元素的覆盖!)

    其中第一大步又是一个双指针的思想:再次分为了以下几步!

    1.判断cur指针位置的值!

    2.决定des向后移动1或2步!(如果cur的值为0则des向后移动两步,否则移动一步)!

    3.判断是否达到原数组的最大长度!即(des的位置是否等于n-1)!若des已经结束,直接跳出循环!

    4.若3不满足,则进行cur++操作!

    5.因为最后des的位置可能是数组长度的最大值,也可能是最大值后面那个值!所以后面还需进行判断是否以及越界!若以越界,再进行修改即可!

    此步骤非常重要!一定要考虑到,如若没有考虑到,那么则会导致越界的问题!

    当第一大步结束时,此时des位置处于最后需要复写的最后一个位置,cur位置为最后一个复写的元素!然后最后进行从后向前完成复写即可!

    画图分析:

    代码实现

    C代码

    1. void duplicateZeros(int* arr, int arrSize)
    2. {
    3. //双指针!解法进行求解!
    4. //首先先找到最后一个复写的元素!
    5. int cur=0;
    6. int des=-1;
    7. while(des
    8. {
    9. if(arr[cur])
    10. {
    11. des++;
    12. }
    13. else if(arr[cur]==0)
    14. {
    15. des+=2;
    16. }
    17. //必须需要注意的是只要des位于最后一个位置即arrSize-1即停止循环!
    18. if(des>=arrSize-1)
    19. {
    20. break;
    21. }
    22. cur++;
    23. }
    24. //经过此时,cur位于最后一个复写的元素!des位于最后一个位置或者之后的位置!
    25. //此时需要注意的是,如果des位于n的位置是,此时已经越界!
    26. if(des==arrSize)
    27. {
    28. arr[arrSize-1]=0;
    29. des-=2;
    30. cur--;
    31. }
    32. while(cur>=0)
    33. {
    34. if(arr[cur]==0)
    35. {
    36. arr[des--]=0;
    37. arr[des--]=0;
    38. }
    39. else
    40. {
    41. arr[des]=arr[cur];
    42. des--;
    43. }
    44. cur--;
    45. }
    46. }

    c++代码

    1. class Solution {
    2. public:
    3. void duplicateZeros(vector<int>& arr)
    4. {
    5. int cur=0;
    6. int des=-1;
    7. int n=arr.size();
    8. while(cur
    9. {
    10. if(arr[cur])
    11. {
    12. des++;
    13. }
    14. else
    15. {
    16. des+=2;
    17. }
    18. if(des>=n-1)
    19. {
    20. break;
    21. }
    22. cur++;
    23. }
    24. if(des==n)
    25. {
    26. arr[n-1]=0;
    27. des-=2;
    28. cur--;
    29. }
    30. while(cur>=0)
    31. {
    32. if(arr[cur]==0)
    33. {
    34. arr[des--]=0;
    35. arr[des--]=0;
    36. }
    37. else
    38. {
    39. arr[des]=arr[cur];
    40. des--;
    41. }
    42. cur--;
    43. }
    44. }
    45. };

    今日分享到此结束!如若还有不懂,欢迎评论区留言!

  • 相关阅读:
    MyBatis-plus使用
    sharding分片键 groovy公式带有非数字字符启动失败
    Vue组件之间传值
    为了带你们搞懂RPC,我手写了一个RPC框架
    复制粘贴,快速将Python程序打包成exe
    游戏视频录制软件对比,哪款最适合你的需求?
    Apisix网关-使用Grafana可视化Apisix的Prometheus数据
    Gnomon绑定基础(约束 IK 节点)
    10月28日
    预训练词嵌入Pretrained Word Embeddings
  • 原文地址:https://blog.csdn.net/weixin_71276184/article/details/133757878