leetcode 2654 使数组所有元素变成1的最少操作次数

一、题目描述

二、解题思路

整体思路

通过找规律,可以分情况来解决这个问题。

具体思路

(1)若数组中存在1,那么就可以以"1"为中心进行扩散,最终将整个数组都变为1,操作次数为nums.size()-one(one为数组中1的个数),返回nums.size()-one,实现代码如下:

//如果数组中存在1

int one=0;

for(auto x:nums)

if(x==1) one++;

if(one) return nums.size()-one;

(2)若数组中不存在1 ,且数组中所有元素的最大公约数不为1,则代表无法将数组中的元素都变成1,就返回-1,如示例2,实现代码如下:

//如果数组所有元素的最大公约数大于1,返回-1

int Gcd=nums0;

for(auto x:nums) Gcd=gcd(Gcd,x);

if(Gcd>1) return -1;

(3)若数组中不存在1但是存在最大公约数为1的子数组 ,那么就可以利用这个子数组,将这个"后天"的1进行扩散,操作次数为length-1+nums.size()-1,即length+nums.size()-2,length为最大公约数为1的数组的元素的个数。

所以,这种情况最少的操作次数即为最大公约数为1的最短子数组的长度length+nums.size()-2,这种情况需要找到最大公约数为1的最短子数组的长度, 可以借助双指针 来解决,实现代码如下:

//如果数组所有元素的最大公约数为1,寻找最短gcd为1的子数组(双指针)

int length=INT_MAX;

for(int left=0;left!=nums.size();left++){

Gcd=numsleft;

for(int right=left;right!=nums.size();right++){

Gcd=gcd(Gcd,numsright);

if(Gcd==1){

length=min(length,right-left+1);

break;

}

}

}

return length+nums.size()-2;

三、代码实现

cpp 复制代码
class Solution {
public:
    int minOperations(vector<int>& nums) {
        //如果数组中存在1
        int one=0;
        for(auto x:nums)
            if(x==1) one++;
        if(one) return nums.size()-one;

        //如果数组所有元素的最大公约数大于1,返回-1
        int Gcd=nums[0];
        for(auto x:nums) Gcd=gcd(Gcd,x);
        if(Gcd>1) return -1;

        //如果数组所有元素的最大公约数为1,寻找最短gcd为1的子数组(双指针)
        int length=INT_MAX;
        for(int left=0;left!=nums.size();left++){
            Gcd=nums[left];
            for(int right=left;right!=nums.size();right++){
                Gcd=gcd(Gcd,nums[right]);
                if(Gcd==1){
                    length=min(length,right-left+1);
                    break;
                }
            }
        }
        return length+nums.size()-2; 
    }

    //求两个数的最大公约数
    int gcd(int a,int b){
        //递归出口
        if(a%b==0) return b;
        else return gcd(b,a%b);
    }
};
相关推荐
北域码匠1 小时前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
卷无止境3 小时前
C++ 的Eigen 库全解析
c++
卷无止境3 小时前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端
郝学胜_神的一滴4 小时前
CMake 27:缓存变量的特性、语法、类型与实操全解
c++·cmake
kisshyshy4 小时前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC15 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户9385156350720 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC21 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥1 天前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者1 天前
Transformer模型部署之性能优化指南
算法