★ 算法OJ题 ★ 力扣1089 - 复写零

**Ciallo~****(∠・ω< )⌒☆ ~**今天,我将和大家一起做 一道双指针算法题--复写零~

目录

[一 题目](#一 题目)

[二 算法解析](#二 算法解析)

[2.1 算法思路](#2.1 算法思路)

[2.2 算法流程](#2.2 算法流程)

[三 编写算法](#三 编写算法)


一 题目

1089. 复写零 - 力扣(LeetCode)

二 算法解析

2.1 算法思路

此题依旧使用双指针算法 ,先根据异地操作,优化成双指针就地操作

如果从前向后 进⾏原地复写操作,由于 0 会复写两次,导致没有复写的数被覆盖

因此我们选择从后往前 的复写策略。但是从后向前复写的时候,我们需要找到最后⼀个复写的数,因此我们的⼤体流程分两步:

  • 先找到最后⼀个复写的数。
  • 从后向前进⾏复写操作。

2.2 算法流程

0.初始化

  • cur = 0, dest = -1

1. 找到最后⼀个复写的数(也使用双指针算法)

  • 判断cur位置的值是否==0
  • ==0 dest指针向后走两步,!=0 dest指针向后走一步
  • 判断dest是否到末位置
  • cur++

1.5. 判断dest是否会越界

  • n-1 位置赋为0
  • cur -= 1 dest -= 2

2. 从后往前,完成复写操作

(i)判断 cur 位置的值:

  • 如果是 0 : dest 以及 dest - 1 位置修改成 0 , dest -= 2 ;
  • 如果⾮零: dest 位置修改成 0 , dest -= 1 ;

(ii)cur-- ,复写下⼀个位置。

三 编写算法

cpp 复制代码
class Solution {
public:
    void duplicateZeros(vector<int>& arr) {
        int cur = 0, dest = -1, n = arr.size();
        // 找到最后⼀个复写的数
        while(cur < n)
        {
            if(arr[cur] == 0)
                dest += 2;
            else
                dest++;
            if(dest >= n - 1)
                break;
            cur++;
        }
        // 判断dest边界情况
        if(dest == n)
        {
            arr[n-1] = 0;
            cur--;
            dest -= 2;
        }
        // 从后往前,完成复写操作
        while(cur >= 0)
        {
            if(arr[cur] == 0)
            {
                arr[dest] = 0;
                arr[--dest] = 0;
                dest--;
                cur--;
            }
            else
            {
                arr[dest] = arr[cur];
                dest--;
                cur--;
            }
        }
    }
};

精简版~:

cpp 复制代码
class Solution
{
public:
	void duplicateZeros(vector<int>& arr)
	{
		// 1. 先找到最后⼀个数
		int cur = 0, dest = -1, n = arr.size();
		while (cur < n)
		{
			if (arr[cur]) dest++;
			else dest += 2;
			if (dest >= n - 1) break;
			cur++;
		}
		// 2. 处理⼀下边界情况
		if (dest == n)
		{
			arr[n - 1] = 0;
			cur--; dest -= 2;
		}
		// 3. 从后向前完成复写操作
		while (cur >= 0)
		{
			if (arr[cur]) arr[dest--] = arr[cur--];
			else
			{
				arr[dest--] = 0;
				arr[dest--] = 0;
				cur--;
			}
		}
	}
};
相关推荐
0xDevNull2 小时前
Java反射机制深度解析:从原理到实战
java·开发语言·后端
小小亮012 小时前
Next.js基础
开发语言·前端·javascript
ALex_zry3 小时前
C++网络编程心跳机制与连接保活:长连接稳定性保障
开发语言·网络·c++
Amumu121383 小时前
Js:正则表达式(二)
开发语言·javascript·正则表达式
学嵌入式的小杨同学3 小时前
STM32 进阶封神之路(三十二):SPI 通信深度实战 —— 硬件 SPI 驱动 W25Q64 闪存(底层时序 + 寄存器配置 + 读写封装)
c++·stm32·单片机·嵌入式硬件·mcu·架构·硬件架构
米粒13 小时前
力扣算法刷题 Day 27
算法·leetcode·职场和发展
Sgf2273 小时前
ES8(ES2017)新特性完整指南
开发语言·javascript·ecmascript
好大哥呀4 小时前
C++ Web 编程
开发语言·前端·c++
ID_180079054734 小时前
小红书笔记评论 API,Python 调用示例与完整 JSON 返回参考
java·开发语言
Fuxiao___4 小时前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#