2025-3-9 leetcode刷题情况(贪心算法--序列问题)

一、376.摆动序列

1.题目描述

2.代码

3.思路

首先判断给的数组的长度,如果小于等于1就返回数组的长度。定义三个变量,一个为当前的差值,一个为前一个的差值,一个存储最长子序列的长度 。然后遍历数组进行循环判断,当前差值等于当前数减前一个数,如果当前差和前一个差分别为正负数,则count加1,再将当前差赋值给前一个差,如此循环,等遍历结束,返回count。

二、738.单调递增的数字

1.题目描述

当且仅当每个相邻位数上的数字 x和 y满足 x<=y时,我们称这个整数是单调递增的。给定一个整数 n,返回小于或等于 n的最大数字,且数字呈单调递增。

2.代码

3.思路

先将整数n转换为字符数组以便逐位操作;从数组倒数第二位开始向前遍历,若发现当前位数字大于后一位数字,就把当前位数字减 1,并记录下从下一位开始后续数字需置为 9 的起始位置;完成上述操作后,从记录的起始位置开始,将后续所有数字置为 9;最后把修改后的字符数组转换回整数并返回。

相关推荐
晴空闲雲1 小时前
线性表-顺序表(Sequential List)
数据结构·算法
Javis2111 小时前
代码随想录算法训练营第九天 |【字符串】151.翻转字符串里的单词、卡码网55.右旋转字符串、28.实现strStr、459.重复的子字符串
数据结构·c++·算法
<但凡.1 小时前
C++修炼:stack和queue
数据结构·c++·算法
努力的小帅1 小时前
c++——二叉树进阶
开发语言·数据结构·c++·学习·算法·面试
朱剑君1 小时前
排序算法——计数排序
数据结构·算法·排序算法
朱剑君1 小时前
排序算法——总结
数据结构·算法·排序算法
鼾声鼾语2 小时前
Nvidia Isaac Sim组装机器人和添加传感器,创建关节树Articulation
运维·算法·安全·机器人·angular.js
White_Can2 小时前
两个数组的交集(暴力、set、哈希)
算法
我不是小upper2 小时前
5 种距离算法总结!!
算法
摄殓永恒2 小时前
【入门】对角线II
数据结构·c++·算法