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

(C语言)力扣 904.水果成篮

写在所有的前面:

本文采用C语言实现代码

目录

  • 写在所有的前面:
  • 题目说明
    • 题目:力扣 904.水果成篮
      • 题目出处
      • 题目描述Description
      • 输入Input
      • 输出Output
      • 样例Sample
      • 限制Hint
  • 解答说明
    • 方案
      • 解题思路
        • 一般情况
        • 特殊情况
      • 代码实现
      • 其他解释

题目说明

题目:力扣 904.水果成篮

题目出处

力扣 904.水果成篮
https://leetcode.cn/problems/fruit-into-baskets/

题目描述Description

你正在探访一家农场,农场从左到右种植了一排果树。这些树用一个整数数组 fruits 表示,其中 fruits[i] 是第 i 棵树上的水果种类 。
你想要尽可能多地收集水果。然而,农场的主人设定了一些严格的规矩,你必须按照要求采摘水果:

  1. 你只有 两个 篮子,并且每个篮子只能装 单一类型 的水果。每个篮子能够装的水果总量没有限制。
  2. 你可以选择任意一棵树开始采摘,你必须从每棵树(包括开始采摘的树)上恰好摘一个水果 。
  3. 采摘的水果应当符合篮子中的水果类型。
  4. 每采摘一次,你将会向右移动到下一棵树,并继续采摘。
  5. 一旦你走到某棵树前,但水果不符合篮子的水果类型,那么就必须停止采摘。

输入Input

一个整数数组 fruits
一个整数 水果数量fruitsSize

输出Output

你可以收集的水果的最大数目。

样例Sample

输入1

fruits = [1,2,1]

输出1

3

解释1

可以采摘全部 3 棵树

输入2

fruits = [0,1,2,2]

输出2

3

解释2

可以采摘 [1,2,2] 这三棵树。
如果从第一棵树开始采摘,则只能采摘 [0,1] 这两棵树。

更多样例见连接

限制Hint

1 <= fruits.length <= 105
0 <= fruits[i] < fruits.length

C语言的代码接口为

int totalFruit(int* fruits, int fruitsSize) {}

自测用主函数部分

int main()
{int fruits[] = { 1,2,1 };printf("%d", totalFruit(fruits, 3));
}

解答说明

方案

解题思路

a 果实,b 果实
nextnum 最近的相同果实数量
allnum 最近的 a b 果实数量
maxnum 最大量

一般情况
  1. 当前水果可摘 if (fruits[i] == a || fruits[i] == b)
    1. 最近的 a b 果实数量allnum +1
    2. 水果相同则最近的相同果实数量nextnum +1
    3. 水果改变则最近的相同果实数量nextnum重置为 1
  2. 当前水果是全新的果实
    1. 通过最近的两水果数量allnum更新最大数量maxnum(保留更大的)
    2. 通过最近的相同果实数量nextnum +1更新最近的两水果数量allnum
    3. 水果改变,最近的相同果实数量nextnum重置为 1
    4. 更新水果种类(保留较近的水果)
特殊情况

遍历所有水果后再更新一次最大数量maxnum
第一颗水果必定更新水果种类if (i == 0)

代码实现

int totalFruit(int* fruits, int fruitsSize)
{int i = 0;//第i颗果树int a = -1, b = -1, nextnum = 0, allnum = 0, maxnum = 0;//a果实,b果实,最近的相同果实数量,最近的ab果实数量,最大量//从前向后遍历while (i < fruitsSize){//如果水果符合if (fruits[i] == a || fruits[i] == b){allnum++;//如果水果相同if (i > 0 && fruits[i] == fruits[i - 1])nextnum++;//如果水果改变elsenextnum = 1;}else //全新的果实{//更新最大数量if (allnum > maxnum)maxnum = allnum;//更新最近的ab果实数量allnum = nextnum + 1;//更新最近相同果实数量nextnum = 1;//更新果实种类if (i == 0 || fruits[i - 1] == b)a = fruits[i];else if (fruits[i - 1] == a)b = fruits[i];}//下一颗果树i++;}//更新最大数量if (allnum > maxnum)maxnum = allnum;return maxnum;
}

其他解释

可能有更优解,但是懒得看了

相关文章:

(C语言)力扣 904.水果成篮

写在所有的前面&#xff1a; 本文采用C语言实现代码 目录 写在所有的前面&#xff1a;题目说明题目&#xff1a;力扣 904.水果成篮题目出处题目描述Description输入Input输出Output样例Sample限制Hint 解答说明方案解题思路一般情况特殊情况 代码实现其他解释 题目说明 题目…...

2024 年12月英语六级CET6听力原文(Lecture部分)

2024 年12月英语六级CET6听力原文(Long Conersation和Passage) 1 牛津大学关于普遍道德准则的研究及相关观点与建议 译文 2 食物颜色对味觉体验及大脑预期的影响 译文 3 财务资源对意义与幸福之间关系的影响研究 译文...

CentOS下,离线安装vscode的步骤;

前置条件&#xff1a; 1.CentOS7; 步骤&#xff1a; 1.下载vscode指定版本&#xff0c;例如&#xff1b; 例如 code-1.83.1-1696982959.el7.x86_64.rpm 2.使用下面命令&#xff1a; sudo rpm -ivh code-1.83.1-1696982959.el7.x86_64.rpm 其他&#xff1a; 卸载vscode的命…...

ubuntu停止.netcore正在运行程序的方法

在Ubuntu系统中停止正在运行的.NET Core程序&#xff0c;你可以使用以下几种方法&#xff1a; 使用kill命令&#xff1a; 如果你知道.NET Core程序的进程ID&#xff08;PID&#xff09;&#xff0c;你可以直接使用kill命令来停止它。首先&#xff0c;使用ps命令配合grep来查找.…...

机器学习基础 衡量模型性能指标

目录 1 前言 ​编辑1.1 错误率(Error rate)&精度(Accuracy)&误差(Error)&#xff1a; 1.2 过拟合(overfitting): 训练误差小&#xff0c;测试误差大 1.3 欠拟合(underfitting)&#xff1a;训练误差大&#xff0c;测试误差大 1.4 MSE: 1.5 RMSE: 1.6 MAE: 1.7 R-S…...

《OpenCV计算机视觉》-对图片的各种操作(均值、方框、高斯、中值滤波处理)及形态学处理

文章目录 《OpenCV计算机视觉》-对图片的各种操作&#xff08;均值、方框、高斯、中值滤波处理&#xff09;边界填充阈值处理图像平滑处理生成椒盐图片均值滤波处理方框滤波处理高斯滤波处理中值滤波处理 图像形态学腐蚀膨胀开运算闭运算顶帽和黑帽 《OpenCV计算机视觉》-对图片…...

如何让Tplink路由器自身的IP网段 与交换机和电脑的IP网段 保持一致?

问题分析&#xff1a; 正常情况下&#xff0c;我的需求是&#xff1a;电脑又能上网&#xff0c;又需要与路由器处于同一局域网下&#xff08;串流Pico4 VR眼镜&#xff09;&#xff0c;所以&#xff0c;我是这么连接 交换机、路由器、电脑 的&#xff1a; 此时&#xff0c;登录…...

【JetPack】Navigation知识点总结

Navigation的主要元素&#xff1a; 1、Navigation Graph&#xff1a; 一种新的XML资源文件,包含应用程序所有的页面&#xff0c;以及页面间的关系。 <?xml version"1.0" encoding"utf-8"?> <navigation xmlns:android"http://schemas.a…...

InnoDB引擎的内存结构

InnoDB擅长处理事务&#xff0c;具有自动崩溃恢复的特性 架构图&#xff1a; 由4部分组成&#xff1a; 1.Buffer Pool&#xff1a;缓冲池&#xff0c;缓存表数据和索引数据&#xff0c;减少磁盘I/O操作&#xff0c;提升效率 2.change Buffer&#xff1a;写缓冲区&#xff0c…...

Y3地图制作1:水果缤纷乐、密室逃脱

文章目录 一、水果缤纷乐1.1 游戏设计1.1.1 项目解析1.1.2 项目优化1.1.3 功能拆分 1.2 场景制作1.2.1 场景需求1.2.2 创建主镜头、绘制草稿&#xff0c;构思文案和情景1.2.3 构建场景地图1.2.4 光源与氛围设置 1.3 游戏初始化1.3.1 物编、UI预设置1.3.2 游戏初始化1.3.2 玩家初…...

ESP32_H2(IDF)学习系列-ADC模数转换(连续转换)

一、简介&#xff08;节选手册&#xff09; 1 概述 ESP32-H2 搭载了以下模拟外设&#xff1a; • 一个 12 位逐次逼近型模拟数字转换器 (SAR ADC)&#xff0c;用于测量最多来自 5 个管脚上的模拟信号。 • 一个温度传感器&#xff0c;用于测量及监测芯片内部温度。 2 SAR ADC 2…...

如何通过TikTok成功引流到独立站

随着短视频平台的迅猛发展&#xff0c;TikTok已成为全球最受欢迎的社交媒体之一&#xff0c;尤其是在年轻用户群体中更是势不可挡。如果你是一个独立站&#xff08;如电商网站、博客、个人品牌站等&#xff09;的运营者&#xff0c;那么如何通过TikTok引流到独立站已经成为一个…...

生成签名文件 .keystore

打开java sdk 到bin目录&#xff08;D:\JDK\Java\jdk1.8.0_202\bin&#xff09;&#xff0c;打开dos窗口执行以下命令&#xff1a; 命令行输入&#xff1a; 1、生成签名文件&#xff1a;&#xff08;-alias 别名 validity 有效期 9125 天&#xff09; keytool -genkeypair -v…...

Mono里运行C#脚本3—mono_jit_init

前面已经介绍了配置参数的读取,这样就可以把一些特殊的配置读取进来,完成了用户配置阶段的参数,接着下来就需要进行大工程的建造了。 为什么这样说呢,因为需要解释并执行C#编译的受托管的代码,相当于就是建立一个C#代码运行的虚拟机,而这个虚拟机还是很复杂的,不但要支…...

龙迅#LT6911C适用于HDMI转MIPI/LVDS产品应用,分辨率高达4K30HZ,内置程序,支持KEY(HDCP)!

1. 描述 LT6911C 是一款高性能 HDMI1.4/DP 转 MIPIDSI/CSI/LVDS 芯片&#xff0c;适用于 VR/智能手机/显示应用。 对于 MIPIDSI/CSI 输出&#xff0c;LT6911C具有可配置的单端口或双端口 MIPIDSI/CSI&#xff0c;具有 1 个高速时钟通道和 1~4 个高速数据通道&#xff0c;运行…...

阿里云虚拟主机ecs镜像如何转移到本地virtualbox上

导出阿里云 ECS 镜像 创建快照:登录阿里云 ECS 控制台,找到对应的 ECS 实例,创建一个快照,等待快照创建完成。创建自定义镜像:基于创建好的快照,创建一个自定义镜像,填写镜像名称和描述等信息。导出镜像:镜像创建完成后,点击 “导出镜像”,并授权访问,将镜像导出到阿…...

虚拟机桥接模式

主机Win10,虚拟机xp 1.虚拟机设置中选择桥接模式 2.在虚拟机菜单&#xff1a;编辑>虚拟机网络编辑&#xff0c;点击“更改设置”&#xff0c;可以看到三个网卡&#xff0c;这三个网卡分别对应不同的网络共享模式。桥接模式须使用VMnet0&#xff0c;如果没看到这个网卡&…...

酷睿i7和i5哪个好?i5和i7的区别介绍

在英特尔酷睿处理器家族中&#xff0c;i7与i5作为面向不同用户群体的主流产品&#xff0c;各自承载着不同的性能定位与使用价值。在面对“酷睿i7和i5哪个好”的问题时&#xff0c;答案并非一概而论&#xff0c;而是取决于具体的应用需求、预算考量以及对性能与效率的期待。本文…...

STM32 高级 谈一下IPV4/默认网关/子网掩码/DNS服务器/MAC

首先可以通过 winr->输入cmd->输入ipconfig 命令可以查看计算机的各种地址 IPV4&#xff1a;是互联网协议第 4 版&#xff08;Internet Protocol version 4&#xff09;所使用的地址。它是一个 32 位的二进制数字&#xff0c;通常被分为 4 个 8 位的部分&#xff…...

Pytorch | 利用FGSM针对CIFAR10上的ResNet分类器进行对抗攻击

Pytorch | 利用FGSM针对CIFAR10上的ResNet分类器进行对抗攻击 CIFAR数据集FGSM介绍FGSM代码实现FGSM算法实现攻击效果 代码汇总fgsm.pytrain.pyadvtest.py 之前已经针对CIFAR10训练了多种分类器&#xff1a; Pytorch | 从零构建AlexNet对CIFAR10进行分类 Pytorch | 从零构建Vgg…...

羊毛鞋履品牌Allbirds仅3900万美元出售全部资产

羊毛运动鞋品牌Allbirds已同意将其全部资产和知识产权以3900万美元的价格出售给American Exchange Group&#xff0c;而这一价格仅约为其2021年IPO时筹集资金3.48亿美元的十分之一&#xff0c;更是其交易首日时超过40亿美元估值的一小部分。Allbirds曾一度成为硅谷人群的非正式…...

OpenClaw飞书集成:Kimi-VL-A3B-Thinking多模态机器人配置教程

OpenClaw飞书集成&#xff1a;Kimi-VL-A3B-Thinking多模态机器人配置教程 1. 为什么选择OpenClaw飞书Kimi-VL-A3B-Thinking组合 去年我在处理团队知识库时&#xff0c;发现一个痛点&#xff1a;每当同事在飞书群聊里分享产品截图或设计稿时&#xff0c;总要手动保存图片再上传…...

霜儿-汉服-造相Z-Turbo镜像5分钟上手:零基础生成古风汉服少女图

霜儿-汉服-造相Z-Turbo镜像5分钟上手&#xff1a;零基础生成古风汉服少女图 1. 镜像简介&#xff1a;一键生成古风汉服少女 想快速生成唯美的古风汉服少女图片&#xff0c;却苦于复杂的AI模型部署&#xff1f;霜儿-汉服-造相Z-Turbo镜像为你提供了开箱即用的解决方案。这个预…...

OpenClaw家庭相册:Kimi-VL-A3B-Thinking智能归档与回忆生成

OpenClaw家庭相册&#xff1a;Kimi-VL-A3B-Thining智能归档与回忆生成 1. 为什么需要智能相册管理 去年夏天整理家庭照片时&#xff0c;我发现自己陷入了数字时代的典型困境——手机里有8000多张照片&#xff0c;电脑硬盘上还有历年备份的3万多张。想找一张孩子第一次走路的照…...

Phi-4-mini-reasoning效果展示:离散数学关系性质判定与反例构造生成

Phi-4-mini-reasoning效果展示&#xff1a;离散数学关系性质判定与反例构造生成 1. 模型能力概览 Phi-4-mini-reasoning是一个专注于数学推理的轻量级开源模型&#xff0c;基于高质量合成数据训练而成。这个模型特别擅长处理需要逻辑推理的数学问题&#xff0c;尤其是离散数学…...

手把手教你用LVGL+FreeRTOS在STM32上实现多页面切换(附完整源码)

手把手教你用LVGLFreeRTOS在STM32上实现多页面切换&#xff08;附完整源码&#xff09; 在嵌入式GUI开发中&#xff0c;页面管理机制的设计直接影响用户体验和代码可维护性。本文将深入探讨如何基于LVGL和FreeRTOS构建一个高效的多页面切换框架&#xff0c;从数据结构设计到实…...

YA-Wiegand:轻量级事件驱动Wiegand协议解析库

1. 项目概述Yet Another Arduino Wiegand Library&#xff08;以下简称 YA-Wiegand&#xff09;是一个专为嵌入式平台设计的轻量级、事件驱动型 Wiegand 协议解析库。它并非简单封装硬件抽象层&#xff0c;而是聚焦于协议语义层的健壮性实现——在不依赖特定 MCU 外设&#xff…...

NaViL-9B中小企业AI落地方案:低成本双卡部署多模态智能助手

NaViL-9B中小企业AI落地方案&#xff1a;低成本双卡部署多模态智能助手 1. 平台介绍 NaViL-9B是上海人工智能实验室研发的原生多模态大语言模型&#xff0c;能够同时处理文本和图像输入&#xff0c;为中小企业提供经济高效的AI解决方案。这款模型特别适合需要同时处理文字和图…...

单片机核心功能解析与实战技巧

1. 单片机学习的核心功能解析作为一名在嵌入式领域摸爬滚打多年的工程师&#xff0c;我深知单片机学习的关键不在于死记硬背&#xff0c;而在于掌握几个核心功能的底层逻辑和应用场景。很多初学者容易陷入"学了很多却不会用"的困境&#xff0c;根本原因就是没有抓住这…...

树莓派5硬件PWM驱动舵机实战:从设备树编译到精准角度控制

树莓派5硬件PWM驱动舵机实战&#xff1a;从设备树编译到精准角度控制 树莓派5作为一款高性能的单板计算机&#xff0c;其硬件PWM功能在机器人、机械臂和模型制作等领域具有广泛的应用前景。与软件PWM相比&#xff0c;硬件PWM能够提供更稳定、更精确的控制信号&#xff0c;特别是…...