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++;
        }
    }
};
相关推荐
LYFlied39 分钟前
【每日算法】LeetCode 136. 只出现一次的数字
前端·算法·leetcode·面试·职场和发展
唯唯qwe-1 小时前
Day23:动态规划 | 爬楼梯,不同路径,拆分
算法·leetcode·动态规划
做科研的周师兄1 小时前
中国土壤有机质数据集
人工智能·算法·机器学习·分类·数据挖掘
来深圳2 小时前
leetcode 739. 每日温度
java·算法·leetcode
LYFlied2 小时前
WebAssembly (Wasm) 跨端方案深度解析
前端·职场和发展·wasm·跨端
yaoh.wang2 小时前
力扣(LeetCode) 104: 二叉树的最大深度 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
hetao17338372 小时前
2025-12-21~22 hetao1733837的刷题笔记
c++·笔记·算法
醒过来摸鱼2 小时前
递归三种分类方法
算法
炽烈小老头3 小时前
【每天学习一点算法 2025/12/22】将有序数组转换为二叉搜索树
学习·算法
jghhh013 小时前
POCS(凸集投影)算法解决部分k空间数据缺失导致吉布斯伪影
算法