Leetcode基础刷题之PHP解析(283. Move Zeroes)

栏目: PHP · 发布时间: 5年前

2 0 1 9 - 4 -19   期五    

  Leetcode基础刷题之 PHP 解析(268. Missing Number)

Leetcode基础刷题之PHP解析(283. Move Zeroes)

给你一个数组,让你写一个函数,把数组中所有的0都转移到数组到最后,并且非0的数之前的顺序保持不变。

第一种解法就是,把非零的数字都往数组的前面推,定义一个变量用来记录最后非0推送的位置,这个时候剩下的坑位都是0的了。

     * @param Integer[] $nums
     * @return NULL
     */
    function moveZeroes(&$nums) {
        $last=0;
        for($i=0;$i<count($nums);$i++) {
            if($nums[$i]){
                $nums[$last++]=$nums[$i];
            }
        }
        for($j=$last;$j<count($nums);$j++) {
            $nums[$j]=0;
        }
    }

解法二

可以利用替换实现。两个指针,一个代表着最前边0的位置,另一个不停的向后面扫,只要不等于0就和最前面的0互换位置,到最后非0顺序也没变,0也跑到了最后。

/**
     * @param Integer[] $nums
     * @return NULL
     */
    function moveZeroes(&$nums) {
        $j=0;
        for($i=0;$i<count($nums);++$i){
            if($nums[$i]){
                $temp=$nums[$i];
                $nums[$i]=$nums[$j];
                $nums[$j]=$temp;
                $j++;
            }
        }
    }

Github整理地址:https://github.com/wuqinqiang/leetcode-php


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

连线力

连线力

杨国斌 / 邓燕华 / 广西师范大学出版社 / 2013-9 / 39.00

《连线力》,最关切我们未来的“思想@网络.中国”丛书之一,互联网中国传媒参考书。 中国网民在行动。在中国的广大网民中,普遍存在着对正义的渴望和追求,对弱者和小人物的同情, 对贪官污吏的痛恶,对政府的失望, 对权贵的嘲讽,对沟通的渴望,甚至对革命的呼唤。这些因素有着共同的内在逻辑,即情感逻辑。在这个意义上,情感汹涌的网络事件,是整个中国社会情感结构的脉络。 1994年,中国开通了全功能的......一起来看看 《连线力》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具