ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

leetcode283-移动零

2022-09-04 16:04:29  阅读:234  来源: 互联网

标签:leetcode283 nums int void ++ length moveZeroes 移动


https://leetcode.cn/problems/move-zeroes/

方法一:双指针法

设置两个指针 i 和 j ,

 1 class Solution {
 2 public:
 3     void moveZeroes(vector<int>& nums) {
 4         int i,j,size=nums.size();
 5         bool flag=false;
 6         for(i=0,j=0;i<size&&j<size;)
 7         {
 8             if(nums[i]!=0)  i++;
 9             if(flag==true)
10             {
11                 if(nums[j]==0)  j++;
12                 else
13                 {
14                     swap(nums[i],nums[j]);
15                     i++;
17                     flag=false;
18                 }     
19             }
20             else    //flag==false
21             {
22                 if(nums[j]!=0)  j++;
23                 else
24                 {
25                     flag=true;j++;
26                 }
27             }
28         }
29     }
30 };

指针 i 一直指向第一个零,其左边全都是非零元素,当 j 在一串零后找到第一个非零数字,i 和 j 所指的元素互换,然后 i 向右移动一位。

更加优雅的代码

public void moveZeroes(int[] nums)  {
    int length;
    if (nums == null || (length = nums.length) == 0) {
        return;
    }
    int j = 0;
    for (int i = 0; i < length; i++) {
        if (nums[i] != 0) {
            if (i > j) {// #1
                nums[j] = nums[i];
                nums[i] = 0;
            }
            j++;
        }
    }
}
public void moveZeroes(int[] nums) 
{
        int i = 0;//统计前面0的个数
        for (int j = 0; j < nums.length; j++) 
        {
            if (nums[j] == 0) 
            {//如果当前数字是0就不操作
                i++;
            } 
            else if (i != 0) 
            {
                //否则,把当前数字放到最前面那个0的位置,然后再把
                //当前位置设为0
                nums[j - i] = nums[j];
                nums[j] = 0;
            }
        }
}

                                

 

方法二:两次遍历

void moveZeroes(int* nums, int numsSize) 
{
    int i = 0,j = 0;
    for(i = 0 ; i < numsSize; i++)
    {
        if(nums[i] != 0)
        {
            nums[j++] = nums[i];
        }
    }
    while(j < numsSize)
    {
        nums[j++] = 0;
    }
}

想象成是两个数组,非0但按顺序放到第二个数组上,后面填0

 

 

 

标签:leetcode283,nums,int,void,++,length,moveZeroes,移动
来源: https://www.cnblogs.com/uacs2024/p/16655245.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有