Leetcode——数组的改变、移动练习

453. 最小操作次数使数组元素相等

本人答案超时

cpp 复制代码
class Solution {
public:
    int minMoves(vector<int>& nums) {
        int len = nums.size();
        int count = 0;
        if (len == 1) {
            count = 0;
        }
        else {
            while (nums[0] != nums[1] || nums[len - 2] != nums[len - 1]) {
                for (int i = 0; i < len - 1; i++) {
                    nums[i]++;
                }
                sort(nums.begin(), nums.end());
                count++;
            }
        }
        return count;
    }
};

本题逆向思维,思路好难想,学习一下

665. 非递减数列

cpp 复制代码
class Solution {
public:
    bool checkPossibility(vector<int>& nums) {
        int count = 0;
        for (int i = 0; i < nums.size() - 1; i++) {
            if (nums[i] > nums[i + 1]) {
                count++;
                if (i > 0 && nums[i + 1] < nums[i - 1]) {
                    nums[i + 1] = nums[i];
                }
            }
        }
        if (count <= 1) {
            return true;
        }
        else {
            return false;
        }
    }
};

283. 移动零


cpp 复制代码
class Solution {
public:
    void moveZeroes(vector<int>& nums) {
        int len = nums.size(), left = 0, right = 0;
        while (right < len) {
            if (nums[right]) {
                swap(nums[left], nums[right]);
                left++;
            }
            right++;
        }
    }
};
相关推荐
ZhengEnCi2 小时前
08c. 检索算法与策略-混合检索
后端·python·算法
程序员小崔日记2 小时前
大三备战考研 + 找实习:我整理了 20 道必会的时间复杂度题(建议收藏)
算法·408·计算机考研
lizhongxuan3 小时前
AI小镇 - 涌现
算法·架构
AI工程架构师6 小时前
通常说算力是多少 FLOPS,怎么理解,GPU和CPU为什么差异这么大
算法
祈安_6 小时前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
归去_来兮20 小时前
拉格朗日插值算法原理及简单示例
算法·数据分析·拉格朗日插值
千寻girling1 天前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
颜酱1 天前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
CoovallyAIHub2 天前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
木心月转码ing2 天前
Hot100-Day14-T33搜索旋转排序数组
算法