当前位置: 首页 > article >正文

帮你从算法的角度来认识数组------( 二 )

引言紧接上文我们来讲一下数组对应的leetcode算法题思路和代码485.最大连续1的个数1要求给定一个二进制数组nums 计算其中最大连续1的个数。2示例示例 1 输入nums [1,1,0,1,1,1] 输出3 解释开头的两位和最后的三位都是连续 1 所以最大连续 1 的个数是 3. 示例 2: 输入nums [1,0,1,1,0,1] 输出23思路我们先定义一个变量current来记录当前1的个数还有一个变量max来记录1的连续最大个数之后就开始循环判断如果为1则current1同时比较当前current和之前max谁大maxmaxcurrent如果不为1将current清零。最终返回最大值max4代码class Solution { public int findMaxConsecutiveOnes(int[] nums) { int current0; int max0; for(int num:nums){ if(num1){ current; maxMath.max(max,current); }else{ current0; } } return max; } }283.移动零1要求给定一个数组nums编写一个函数将所有0移动到数组的末尾同时保持非零元素的相对顺序。请注意必须在不复制数组的情况下原地对数组进行操作。2示例示例 1: 输入: nums [0,1,0,3,12] 输出: [1,3,12,0,0] 示例 2: 输入: nums [0] 输出: [0]3思路我们可以用一个指针来依次移动旨在将后面不为0的元素赋值到指针所指位置这样就实现了非0元素都在数组前面当所有非0元素遍历完后将指针后面的位置全赋值为0这样就可以实现题意4代码class Solution { public void moveZeroes(int[] nums) { int index0; int nnums.length; for(int i0;in;i){ if(nums[i]!0){ nums[index]nums[i]; index; } } for(int jindex;jn;j){ nums[j]0; } } }27.移除元素1要求给你一个数组nums和一个值val你需要原地移除所有数值等于val的元素。元素的顺序可能发生改变。然后返回nums中与val不同的元素的数量。假设nums中不等于val的元素数量为k要通过此题您需要执行以下操作① 更改nums数组使nums的前k个元素包含不等于val的元素。nums的其余元素和nums的大小并不重要。② 返回k。2示例示例 1 输入nums [3,2,2,3], val 3 输出2, nums [2,2,_,_] 解释你的函数应该返回 k 2, 并且 nums 中的前两个元素均为 2。 你在返回的 k 个元素之外留下了什么并不重要因此它们并不计入评测。 示例 2 输入nums [0,1,2,2,3,0,4,2], val 2 输出5, nums [0,1,4,0,3,_,_,_] 解释你的函数应该返回 k 5并且 nums 中的前五个元素为 0,0,1,3,4。 注意这五个元素可以任意顺序返回。 你在返回的 k 个元素之外留下了什么并不重要因此它们并不计入评测。3思路和上一题思路基本一致用一个指针用来依次遍历数组将循环中找到的后面不等于val的值放在指针所指位置循环原则边循环坐标边比较该坐标的值是否等于val若等于则跳过若不同则将该值覆盖到指针所指位置最后返回指针所指下标值可能描述的有点不太清楚直接看代码4代码class Solution { public int removeElement(int[] nums, int val) { int slow0; for(int fast0;fastnums.length;fast){ if(nums[fast]!val){ //不相同则覆盖覆盖成不等于val的元素 nums[slow]nums[fast]; slow; } } return slow; } }小舟有话说做完这三道可以尝试一下其他的数组相关题目下一个知识点是链表哦如果有帮助到你的话点点关注~下次找我不迷路

相关文章:

帮你从算法的角度来认识数组------( 二 )

引言紧接上文,我们来讲一下数组对应的leetcode算法题思路和代码485.最大连续1的个数(1)要求给定一个二进制数组 nums , 计算其中最大连续 1 的个数。(2)示例:示例 1: 输入&#xff1…...

MaxViT多轴注意力机制详解:从理论到PyTorch实现

1. MaxViT多轴注意力机制的核心思想 第一次看到MaxViT论文时,我被它优雅的设计思路惊艳到了。这个由Google Research团队发表在ECCV 2022上的工作,完美解决了传统视觉Transformer在处理高分辨率图像时的计算瓶颈问题。 想象一下你在看一幅画:…...

Coze工作流实战:我把飞书多维表格变成了一个“第一人称视频”自动生产线

Coze工作流实战:打造企业级第一人称视频自动化生产线 想象一下这样的场景:电商大促前夕,运营团队需要为200款商品分别制作沉浸式体验视频;市场部门计划在三天内为全国30个城市的分店生成本地化活动宣传素材;社交媒体团…...

DevSecOps实战 | 如何利用Black Duck实现开源组件安全与合规的左移策略

1. 为什么开源组件安全需要"左移"? 记得去年参与一个金融项目时,开发团队在交付前两周突然发现使用的某个开源日志组件存在高危漏洞。紧急排查发现这个组件被17个微服务间接引用,最后不得不通宵达旦地修改代码。这种"最后一刻…...

隐私搜索神器SearXNG实战:用绿联NAS+Docker打造专属搜索引擎(含Open-WebUI优化技巧)

隐私搜索神器SearXNG实战:用绿联NASDocker打造专属搜索引擎(含Open-WebUI优化技巧) 在信息爆炸的时代,隐私保护已成为技术爱好者的刚需。SearXNG作为一款开源的元搜索引擎,不仅能聚合多个搜索引擎的结果,还…...

Gazebo仿真进阶:PX4自定义无人机模型从零到实战(附STL文件处理技巧)

Gazebo仿真进阶:PX4自定义无人机模型从零到实战(附STL文件处理技巧) 在无人机开发领域,仿真环境的重要性不言而喻。它不仅能大幅降低硬件测试成本,还能加速算法验证和系统迭代。Gazebo作为业界领先的机器人仿真平台&am…...

3DXML 转 UG 的实用技巧与迪威模型网高效转换方案

1. 为什么你需要把3DXML转成UG?聊聊我的亲身经历 我干了这么多年机械设计和产品开发,最头疼的事情之一就是客户或者上游供应商发来的模型文件,我自己的软件打不开。相信很多用UG(现在官方叫NX,但大家还是习惯叫UG&…...

Linux网络故障排查:RTNETLINK answers: Network is unreachable的三种实战修复方案

1. 遇到"Network is unreachable"时先别慌 第一次在Linux终端里看到RTNETLINK answers: Network is unreachable这个报错时,我正急着部署服务器,结果连最基本的ping测试都失败。这个错误就像一堵突然出现的墙,把整个网络通信拦腰截…...

OpenHarmony 5.0.2 音频驱动适配:从ADM配置到RK809寄存器调试实战

1. 音频驱动适配背景与问题定位 最近在RK3568开发板上适配OpenHarmony 5.0.2系统时,遇到了一个典型的音频问题:编译后耳机可以正常发声,但内置喇叭完全无声,而且插入耳机时扬声器也不会自动切换。这种问题在嵌入式开发中很常见&am…...

GM1602lib:面向CO传感器的轻量级模拟驱动设计

1. GM1602lib 库概述:面向 Honeywell GM1602-CO 气体传感器的嵌入式驱动设计GM1602lib 是一个专为 Honeywell GM1602-CO 一氧化碳(CO)气体传感器设计的 Arduino 兼容驱动库。该库并非基于数字通信协议(如 IC 或 SPI)&a…...

基于STM32的智能旅行箱嵌入式系统设计

1. 项目概述智能旅行箱已从概念走向工程实践,其核心挑战在于多模态感知、低功耗实时响应与机械执行系统的协同。本项目以STM32F103RCT6为控制中枢,构建了一套具备防盗报警、语音交互、运动控制、环境感知与人机协同能力的嵌入式系统。区别于单一功能模块…...

Pixel Dimension Fissioner算力优化:动态批处理适配不同长度文本输入

Pixel Dimension Fissioner算力优化:动态批处理适配不同长度文本输入 1. 技术背景与挑战 Pixel Dimension Fissioner作为一款基于MT5-Zero-Shot-Augment核心引擎构建的文本增强工具,在处理不同长度的文本输入时面临显著的算力优化挑战。传统批处理方法…...

Hunyuan-MT-7B对比实测:与Google翻译等主流工具效果对比

Hunyuan-MT-7B对比实测:与Google翻译等主流工具效果对比 在翻译需求无处不在的今天,我们面临的选择似乎很多:Google翻译、DeepL、百度翻译……这些在线工具触手可及,但当你需要处理专业文档、少数民族语言或长文本时,…...

Simulink信号源模块隐藏技巧:90%用户不知道的Band-Limited White Noise和Chirp Signal高级配置

Simulink信号源模块隐藏技巧:90%用户不知道的Band-Limited White Noise和Chirp Signal高级配置 在工程仿真领域,Simulink的信号源模块就像画家的调色板,但大多数用户只使用了基础颜色。本文将揭示那些被忽视却极具价值的参数配置技巧&#xf…...

Android开发者必看:360加固保最新配置避坑指南(2024版)

Android应用安全加固实战:360加固保2024高效配置与深度优化指南 移动应用安全已成为开发者不可忽视的核心议题。作为国内领先的Android应用保护方案,360加固保持续迭代其防护能力,但许多开发团队在实际配置过程中仍会遇到各种"暗礁"…...

Android相机开发避坑指南:从Camera1到CameraX的实战迁移心得

Android相机开发演进实战:从Camera1到CameraX的深度迁移策略 移动端相机开发一直是Android开发者面临的技术高地之一。从早期的Camera1 API到如今Jetpack组件中的CameraX,Google不断优化相机开发体验,但版本间的巨大差异也让开发者面临诸多迁…...

基于COMSOL平台,探讨二氧化碳驱替甲烷模型:单场效应下的气体驱替效应研究

COMSOL 注二氧化碳驱替甲烷模型 没有考虑多场耦合 只考虑了气体的驱替效应在油气田开发过程中,CO₂驱替煤层气的数值模拟总是充满挑战。最近看到有人用COMSOL搭建了纯气体驱替模型,但仔细看参数设置发现这个模型存在明显短板——它把复杂的多物理场问题简…...

虚拟机锁定文件残留问题全解析:从.lck文件清理到权限修复

1. 虚拟机锁定文件问题的本质 刚接触虚拟机的朋友可能会遇到这样的场景:前一天用得好好的虚拟机,第二天开机突然提示"该虚拟机似乎正在使用中"。这种情况就像你去图书馆借书,系统显示书已经被借出,但实际上书就好好躺在…...

COMSOL模拟下的枝晶生长与电化学沉积模型:典型成核、随机成核、均匀沉积及雪花晶形成过程的综合研究

comsol枝晶生长,沉积模型,包括:典型,形状成核,随机成核,均匀沉积,雪花晶形成过程。 适用于电池,电化学沉积,催化的模拟学习。COMSOL里折腾枝晶生长模型的时候&#xff0c…...

Tsmaster工程:强大替代Canoe的国产软件,降低成本与节约开发时间的理想解决方案

Tsmaster工程,目前最为强大的替换canoe的国产软件,如果想降低成本,或者节约开发时间,请找我们,可以为您提供理想的解决方案(包括can/canfd一致性测试,uds,标定,canoe测试…...

【GitHub项目推荐--LobsterBoard:OpenClaw 生态的可视化仪表盘构建器】⭐⭐⭐

简介 LobsterBoard 是一个专为 OpenClaw​ 智能体框架设计的开源、自托管仪表盘构建器。它允许用户通过简单的拖拽操作,将系统监控、AI 使用统计、天气、日历、待办事项等 60 多种小部件(Widgets)组合成个性化的控制面板。与传统的命令行监控…...

【GitHub项目推荐--Page Agent:网页内的 GUI 智能体】⭐⭐⭐

简介 Page Agent 是由阿里巴巴开源的一款纯前端 GUI 智能体框架,其核心理念是 “The GUI Agent Living in Your Webpage”。它颠覆了传统 Web 自动化需要依赖后端服务、无头浏览器或浏览器插件的模式,直接将 AI 智能体嵌入到网页中运行。用户通过自然语…...

【GitHub项目推荐--OpenClaw Dashboard:AI 智能体的可视化运维中心】⭐⭐

简介 OpenClaw Dashboard 是由开发者 Tugcan Topaloglu 构建的一款开源、安全、实时的 Web 监控面板,专为 OpenClaw​ AI 智能体框架设计。它解决了原生 OpenClaw 在命令行(CLI)模式下难以直观监控多智能体状态、成本消耗及系统资源的痛点。…...

计算机毕业设计springboot基于的房屋租赁系统 基于Spring Boot的智能化房源管理与租赁撮合系统 基于Spring Boot的房屋出租信息发布与在线签约平台

计算机毕业设计springboot基于的房屋租赁系统 (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。随着城市化进程的加速推进与人口流动性的显著增强,异地求学、就业、生活…...

Java对象内存分配全解:从new Student()到this关键字,一张图看懂对象在内存中的完整生命周期

当你写下这行代码时:Student stu new Student();你有没有想过,这短短一行代码,在内存中到底发生了什么?对象存在哪里?stu变量里存的到底是什么?为什么方法里修改对象的属性,外面的对象也跟着变…...

用过才敢说! 全场景通用降AIGC平台 千笔·专业降AI率智能体 VS 万方智搜AI

在AI技术迅速发展的今天,越来越多的学术工作者和学生开始依赖AI工具来提升写作效率。然而,随着查重系统对AI生成内容的识别能力不断提升,论文中的“AI痕迹”问题日益凸显,成为影响学术成果合规性的关键障碍。许多人在使用AI辅助写…...

横评后发现 9个降AI率工具:专科生必看的降AI率测评与推荐

在当前学术写作中,AI生成内容(AIGC)的广泛应用让论文查重率和AI痕迹成为学生必须面对的问题。尤其是对于专科生来说,论文写作不仅需要符合学术规范,还要避免被系统识别为AI生成内容,这使得“降AI率”、“去…...

2026年科研党收藏!圈粉无数的降AIGC网站 —— 千笔

在AI技术快速发展的今天,越来越多的科研人员、学生和职场人士开始借助AI工具辅助论文写作。然而,随着查重系统对AI生成内容的识别能力不断提升,如何有效降低AI率和重复率成为学术写作中的一大难题。面对市场上五花八门的降AI率和降重复率工具…...

少走弯路:顶流之选的降AIGC软件 —— 千笔·专业降AI率智能体

在AI技术迅猛发展的今天,越来越多的学生、研究人员和职场人士开始借助AI工具进行论文写作与内容创作。然而,随着学术审核标准的不断提升,AI生成内容的痕迹愈发明显,导致论文面临“AI率超标”的风险。知网、维普、万方等查重系统不…...

用过才敢说! 更贴合全场景通用的降AI率网站,千笔·降AIGC助手 VS 知文AI

在AI技术迅速发展的今天,越来越多的学生、研究人员和职场人士开始借助AI工具进行论文写作和内容创作。然而,随着学术审核标准的不断提升,AI生成内容的痕迹愈发明显,查重系统对AIGC的识别能力也不断增强。面对日益严格的合规要求&a…...