经典算法题详解之切分数组(一)

我们先来看题目描述:

给定一个整数数组 nums,小李想将 nums 切割成若干个非空子数组,使得每个子数组最左边的数和最右边的数的最大公约数大于 1 。为了减少他的工作量,请求出最少可以切成多少个子数组。​

示例 1

输入:nums = [2,3,3,2,3,3]

输出:2

解释:最优切割为 [2,3,3,2] 和 [3,3] 。第一个子数组头尾数字的最大公约数为 2 ,第二个子数组头尾数字的最大公约数为 3 。

示例 2

输入:nums = [2,3,5,7]

输出:4

解释:只有一种可行的切割:[2], [3], [5], [7]

限制

  • 1 <= nums.length <= 10^5
  • 2 <= nums[i] <= 10^6
相关推荐
松涛和鸣2 小时前
28、Linux文件IO与标准IO详解:从概念到实战
linux·网络·数据结构·算法·链表·list
长安er2 小时前
LeetCode 167/15 两数之和与三数之和-双指针1
算法·leetcode·双指针·两数之和·三数之和
凌盛羽3 小时前
在STM32G030xx的HAL库中使用DMA采集ADC多通达数据并开启DMA开启全满和半满中断
数据结构·stm32·单片机·嵌入式硬件·链表·嵌入式实时数据库
Hello娃的3 小时前
【神经网络】反向传播BP算法
人工智能·神经网络·算法
遗憾是什么.3 小时前
数据结构 -- 链表
数据结构·链表
lynnlovemin3 小时前
从暴力到高效:C++ 算法优化实战 —— 排序与双指针篇
java·c++·算法
hweiyu003 小时前
数据结构:无向图
数据结构
jinxinyuuuus3 小时前
快手在线去水印:短链解析、API逆向与视频流的元数据重构
前端·人工智能·算法·重构
Flash.kkl3 小时前
优先算法专题十五——BFS_FloodFill
算法·宽度优先