欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > 名人名企 > LintCode第539题-移动零,767题-翻转数组

LintCode第539题-移动零,767题-翻转数组

2025/5/8 10:09:46 来源:https://blog.csdn.net/softstarhhy/article/details/147758438  浏览:    关键词:LintCode第539题-移动零,767题-翻转数组

第539题

描述

给一个数组 nums 写一个函数将 0 移动到数组的最后面,非零元素保持原数组的顺序

注意:1.必须在原数组上操作
        2.最小化操作数

样例

例1:

输入: nums = [0, 1, 0, 3, 12],
输出: [1, 3, 12, 0, 0].

例2:

输入: nums = [0, 0, 0, 3, 1],
输出: [3, 1, 0, 0, 0].

代码如下:

public class Solution {

    /**

     * @param nums: an integer array

     * @return: nothing

     */

    public void moveZeroes(int[] nums) {

        // write your code here

        int n=nums.length;

        int i=0;

        for(int j=0;j<n;j++)//采用直接交换

        {

            if(nums[j]!=0)

            {

                swap(nums,i,j);

                i++;

            }

        }

    }

    void swap(int[] nums,int beforeIndex,int afterIndex)

    {

        int temp=nums[beforeIndex];

        nums[beforeIndex]=nums[afterIndex];

        nums[afterIndex]=temp;

    }

}

第767题

描述

原地意味着你不能使用额外空间

样例 1:

输入 : nums = [1,2,5]
输出 : [5,2,1]

代码如下:

 

public class Solution {

    /**

     * @param nums: a integer array

     * @return: nothing

     */

    public void reverseArray(int[] nums) {

        // write your code here

        int n=nums.length;

        for(int i=0;i<n/2;i++)

        {

            swap(nums,i,n-i-1);

        }


 

    }

            void swap(int[] nums,int beforeIndex,int afterIndex)

    {

        int temp=nums[beforeIndex];

        nums[beforeIndex]=nums[afterIndex];

        nums[afterIndex]=temp;

    }

}

 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词