【优选算法】——双指针——Leetcode——283.移动零

简介: 【优选算法】——双指针——Leetcode——283.移动零

1.题目


283. 移动零


提示


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


请注意 ,必须在不复制数组的情况下原地对数组进行操作。


示例 1:


输入: nums =

[0,1,0,3,12]


输出:

[1,3,12,0,0]


示例 2:


输入: nums =

[0]


输出:

[0]

提示:


1 <= nums.length <= 104

-231 <= nums[i] <= 231 - 1

2. 解法(快排的思想:数组划分区间-数组分两块):



1.算法思路:


在本题中,我们可以⽤⼀个 cur 指针来扫描整个数组,另⼀个 dest 指针⽤来记录⾮零数序列

的最后⼀个位置。根据 cur 在扫描的过程中,遇到的不同情况,分类处理,实现数组的划分。?

在? cur ?遍历期间,使? [0, dest] ?的元素全部都是⾮零元素, [dest + 1, cur - 1] ?的

元素全是零。


2.算法流程:

image.png


a. 初始化cur = 0 (⽤来遍历数组),dest = -1 (指向⾮零元素序列的最后⼀个位置。

因为刚开始我们不知道最后⼀个⾮零元素在什么位置,因此初始化为? -1 )

b. cur 依次往后遍历每个元素,遍历到的元素会有下⾯两种情况:

i. 遇到的元素是 0 , cur 直接 ++ 。因为我们的⽬标是让 [dest + 1, cur - 1] 内

的元素全都是零,因此当 cur 遇到 0 的时候,直接 ++ ,就可以让 0 在cur - 1

的位置上,从⽽在 [dest + 1, cur - 1] ?内;

ii. 遇到的元素不是0 , dest++ ,并且交换 cur 位置和 dest 位置的元素,之后让

cur++ ,扫描下⼀个元素。

• 因为 dest 指向的位置是⾮零元素区间的最后⼀个位置,如果扫描到⼀个新的⾮零元

素,那么它的位置应该在? dest + 1 的位置上,因此dest 先⾃增 1 ;

• dest++ 之后,指向的元素就是 0 元素(因为⾮零元素区间末尾的后⼀个元素就是

0 ),因此可以交换到cur 所处的位置上,实现 [0, dest] 的元素全部都是⾮零

元素, [dest + 1, cur - 1] 的元素全是零。


3.代码实现


1.C语言

void moveZeroes(int* nums, int numssize) {
    for ( int cur = 0, dest = -1; cur < numssize; cur++) {
        if (nums[cur]) { // 处理非零元素
            dest++;
            int temp = nums[dest];
            nums[dest] = nums[cur];
            nums[cur] = temp;
        }
    }
}

2.C++

class Solution {
public:
    void moveZeroes(vector<int>& nums)
   {
   for(int cur = 0, dest = -1; cur < nums.size(); cur++)
   if(nums[cur]) // 处理⾮零元素
   swap(nums[++dest], nums[cur]);
    }
};

image.png

相关文章
|
1天前
|
存储 算法 调度
力扣中级算法(Python)
力扣中级算法(Python)
|
1天前
|
算法 Python
力扣初级算法(Python)(二)
力扣初级算法(Python)(二)
|
2天前
|
算法
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
|
2天前
|
算法
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
|
2天前
|
算法
【经典LeetCode算法题目专栏分类】【第9期】深度优先搜索DFS与并查集:括号生成、岛屿问题、扫雷游戏
【经典LeetCode算法题目专栏分类】【第9期】深度优先搜索DFS与并查集:括号生成、岛屿问题、扫雷游戏
|
2天前
|
算法
【经典LeetCode算法题目专栏分类】【第8期】滑动窗口:最小覆盖子串、字符串排列、找所有字母异位词、 最长无重复子串
【经典LeetCode算法题目专栏分类】【第8期】滑动窗口:最小覆盖子串、字符串排列、找所有字母异位词、 最长无重复子串
|
2天前
|
算法
【经典LeetCode算法题目专栏分类】【第7期】快慢指针与链表
【经典LeetCode算法题目专栏分类】【第7期】快慢指针与链表
|
1天前
|
算法 JavaScript 决策智能
基于禁忌搜索算法的TSP路径规划matlab仿真
**摘要:** 使用禁忌搜索算法解决旅行商问题(TSP),在MATLAB2022a中实现路径规划,显示优化曲线与路线图。TSP寻找最短城市访问路径,算法通过避免局部最优,利用禁忌列表不断调整顺序。关键步骤包括初始路径选择、邻域搜索、解评估、选择及禁忌列表更新。过程示意图展示搜索效果。
|
1天前
|
机器学习/深度学习 算法
基于BP神经网络和小波变换特征提取的烟草香型分类算法matlab仿真,分为浓香型,清香型和中间香型
```markdown 探索烟草香型分类:使用Matlab2022a中的BP神经网络结合小波变换。小波分析揭示香气成分的局部特征,降低维度,PCA等用于特征选择。BP网络随后处理这些特征,以区分浓香、清香和中间香型。 ```
|
2天前
|
机器学习/深度学习 算法
m基于PSO-GRU粒子群优化长门控循环单元网络的电力负荷数据预测算法matlab仿真
摘要: 在MATLAB 2022a中,对比了电力负荷预测算法优化前后的效果。优化前为&quot;Ttttttt111222&quot;,优化后为&quot;Tttttttt333444&quot;,明显改进体现为&quot;Tttttttttt5555&quot;。该算法结合了粒子群优化(PSO)和长门控循环单元(GRU)网络,利用PSO优化GRU的超参数,提升预测准确性和稳定性。PSO模仿鸟群行为寻找最优解,而GRU通过更新门和重置门处理长期依赖问题。核心MATLAB程序展示了训练和预测过程,包括使用&#39;adam&#39;优化器和超参数调整,最终评估并保存预测结果。
6 0