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++;
        }
    }
};
相关推荐
汀、人工智能1 分钟前
[特殊字符] 第70课:加油站
数据结构·算法·数据库架构·图论·bfs·加油站
June bug2 分钟前
全链路测试
功能测试·面试·职场和发展
wsoz6 分钟前
Leetcode普通数组-day5、6
c++·算法·leetcode·数组
y = xⁿ7 分钟前
【LeetCode】双指针:同向快慢针
算法·leetcode
啊哦呃咦唔鱼8 分钟前
LeetCode hot100-105从前序与中序遍历序列构造二叉树
算法
favour_you___9 分钟前
2026_4_8算法练习题
数据结构·c++·算法
汀、人工智能18 分钟前
[特殊字符] 第57课:搜索旋转排序数组
数据结构·算法·数据库架构·图论·bfs·搜索旋转排序数组
倦王22 分钟前
力扣日刷47
算法·leetcode·职场和发展
MicroTech202525 分钟前
突破量子数据加载瓶颈,MLGO微算法科技推出面向大规模量子计算的分治态制备技术
科技·算法·量子计算
码王吴彦祖26 分钟前
顶象 AC 纯算法迁移实战:从补环境到纯算的完整拆解
java·前端·算法