首页 > 其他分享 >leetcode283-移动零

leetcode283-移动零

时间:2022-09-04 15:57:10浏览次数:53  
标签: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,移动
From: https://www.cnblogs.com/uacs2024/p/16655245.html

相关文章

  • 响应式模版移动优化
    本文重点介绍做SEO响应式模版移动优化:响应式模版是指只有一套模版,pc和手机端共用一套模版,模版可根据浏览窗口自适应,只有一个www的连接。 响应式模版优化需做以下几点:1......
  • 【校招VIP】[前端][一本][6分]项目需要考虑到PC端和移动端
    关注【校招VIP】公众号,回复【简历】,添加校招顾问微信,即可获取简历指导!本份简历是一位21届一本前端同学的简历,简历评分6分。一、学员简历二、指导意见简历模板没有问题......
  • 用Vue框架实现 - 移动端的tabbar
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metahttp-equiv="X-UA-Compatible"content="IE=edge"><metaname="viewport"conten......
  • 移动测试学习
    移动测试一、兼容性测试1、WEBWEB:EDGE,Chrome,Firefox,苹果浏览器移动互联网:UC浏览器,QQ浏览器2、APP①、操作系统:需要考虑APP在主流平台上的页面展示和样式的加载,目前考......
  • 移动测试Ⅱ
    功能测试点用户使用习惯权限问题硬件问题比如双卡双待、摄像头、GPU等。操作习惯用户常用的有菜单键、Home键、返回键、Home键长按(显示当前进程列表)、调整音量、待机......
  • 移动测试
    移动APP测试首先搭建android-sdk环境1.搭建安卓环境,首先确保java环境ok。2.下载androidsdk文件后,解压androidsdk,进入到文件里面,可以看到如下的截图:   3.打......
  • 移动自动化测试(二)
    功能测试点用户使用习惯权限问题硬件问题比如双卡双待、摄像头、GPU等。操作习惯用户常用的有菜单键、Home键、返回键、Home键长按(显示当前进程列表)、调整音量、待机......
  • 无需花费一分钱即可成为跨平台移动开发人员的完整路线图。
    无需花费一分钱即可成为跨平台移动开发人员的完整路线图。嘿。在本文中,我将与您分享我为成为跨平台软件开发人员所做的方式和事情,而无需在课程或大学上花费一美元。这不......
  • 工具函数(JavaScript)——如何判断设备是不是移动端
    浏览器有一个Navigator接口,表示用户代理的状态和标识。Navigator.userAgent可以知道客户端的设备类型。请求的请求标头有一个user-agent字段,内容中包含了设备型号的信......
  • 移动测试
    移动测试测试总结移动测试主要使⽤的平台为Android和IOS的平台,因此针对移动平台的测试,和WEB平台的测试,是存在不同的思维⽅式的。这些不同的思维⽅式具体总结如下。兼......