15天算法入门(三)

简介: 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

网络异常,图片无法展示
|


网络异常,图片无法展示
|


移动零


题目


给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。


示例:
输入: [0,1,0,3,12]
输出: [1,3,12,0,0]


题解


思路一:

遍历数组,将为0的数删除。最后将后面缺失的位置补0。

网络异常,图片无法展示
|

思路二:

使用左右指针指向为0的左右边界。当遍历遇到不为0的数值时,将该值与左边界的0交换,左右边界向后移;遇到的值为0时,直接扩展0的有边界,继续下一步骤。

网络异常,图片无法展示
|

网络异常,图片无法展示
|


代码


思路一:


var moveZeroes = function (nums) {
    let len = nums.length - 1
    for (let i = 0; i < nums.length; i++) {
        if (nums[i] == 0) {
            nums.splice(i, 1)
            i--
        }
    }
    while (nums.length <= len) {
        nums.push(0)
    }
    return nums
};


思路二:


var moveZeroes = function (nums) {
    let l = 0, r = 0, index = 0
    while (index < nums.length) {
        if (nums[index] == 0) {
            r = index++
        } else {
            swap(nums, l++, index++)
            r++
        }
    }
    return nums
};
function swap(arr, i, j) {
    let temp = arr[i]
    arr[i] = arr[j]
    arr[j] = temp
}

网络异常,图片无法展示
|


两数之和 II - 输入有序数组


题目


给定一个已按照 升序排列  的整数数组 numbers ,请你从数组中找出两个数满足相加之和等于目标数 target 。


函数应该以长度为 2 的整数数组的形式返回这两个数的下标值。numbers 的下标 从 1 开始计数 ,所以答案数组应当满足 1 <= answer[0] < answer[1] <= numbers.length 。


你可以假设每个输入只对应唯一的答案,而且你不可以重复使用相同的元素。


示例 1:
输入:numbers = [2,7,11,15], target = 9
输出:[1,2]
解释:2 与 7 之和等于目标数 9 。因此 index1 = 1, index2 = 2 。


题解


在输入的数组中,必然有唯一一对答案存在,所以我们可以忽略没有的情况。顺序数组中使用左右指针,分别指向头和尾。判断两者相加情况:相等直接返回;大于目标值,说明尾部数值过大,缩小范围,将右指针左移;小于目标值,说明左指针数值过小,左指针右移。直到左右指针相遇。


网络异常,图片无法展示
|

代码


var twoSum = function (numbers, target) {
    let l = 0, r = numbers.length - 1, mid
    while (l < r) {
        if (numbers[l] + numbers[r] === target) return [l + 1, r + 1]
        if (numbers[l] + numbers[r] > target) r--
        else if (numbers[l] + numbers[r] < target) l++
    }
    return [-1, -1]
};


题目来源:leetcode

目录
相关文章
|
2月前
|
机器学习/深度学习 人工智能 算法
深度学习入门:理解神经网络与反向传播算法
【9月更文挑战第20天】本文将深入浅出地介绍深度学习中的基石—神经网络,以及背后的魔法—反向传播算法。我们将通过直观的例子和简单的数学公式,带你领略这一技术的魅力。无论你是编程新手,还是有一定基础的开发者,这篇文章都将为你打开深度学习的大门,让你对神经网络的工作原理有一个清晰的认识。
|
1月前
|
机器学习/深度学习 算法
机器学习入门(三):K近邻算法原理 | KNN算法原理
机器学习入门(三):K近邻算法原理 | KNN算法原理
|
1月前
|
机器学习/深度学习 算法 大数据
机器学习入门:梯度下降算法(下)
机器学习入门:梯度下降算法(下)
|
1月前
|
机器学习/深度学习 算法 API
机器学习入门(五):KNN概述 | K 近邻算法 API,K值选择问题
机器学习入门(五):KNN概述 | K 近邻算法 API,K值选择问题
|
1月前
|
机器学习/深度学习 算法
机器学习入门:梯度下降算法(上)
机器学习入门:梯度下降算法(上)
|
3月前
|
机器学习/深度学习 人工智能 算法
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
本文全面介绍了人工智能(AI)的基础知识、操作教程、算法实现及其在实际项目中的应用。首先,从AI的概念出发,解释了AI如何使机器具备学习、思考、决策和交流的能力,并列举了日常生活中的常见应用场景,如手机助手、推荐系统、自动驾驶等。接着,详细介绍了AI在提高效率、增强用户体验、促进技术创新和解决复杂问题等方面的显著作用,同时展望了AI的未来发展趋势,包括自我学习能力的提升、人机协作的增强、伦理法规的完善以及行业垂直化应用的拓展等...
182 3
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
|
4月前
|
机器学习/深度学习 数据采集 人工智能
机器学习算法入门与实践
【7月更文挑战第22天】机器学习算法入门与实践是一个既充满挑战又极具吸引力的过程。通过掌握基础知识、理解常见算法、注重数据预处理和模型选择、持续学习新技术和参与实践项目,你可以逐步提高自己的机器学习技能,并在实际应用中取得优异的成绩。记住,机器学习是一个不断迭代和改进的过程,保持好奇心和耐心,你将在这个领域走得更远。
|
4月前
|
消息中间件 存储 算法
实战算法的基础入门(2)
实战算法的基础入门
|
4月前
|
算法 大数据
实战算法的基础入门(1)
实战算法的基础入门
|
4月前
|
算法 Java
实战算法的基础入门(3)
实战算法的基础入门
下一篇
无影云桌面