734.单调递增的数字
当且仅当每个相邻位数上的数字 x
和 y
满足 x <= y
时,我们称这个整数是单调递增的。
给定一个整数 n
,返回 小于或等于 n
的最大数字,且数字呈 单调递增 。
示例 1:
输入: n = 10 输出: 9
示例 2:
输入: n = 1234 输出: 1234
示例 3:
输入: n = 332 输出: 299
思路:
将n转化为string str,定义一个变量flag初始为str.size(),从后往前遍历,判断str[i]<str[i-1],str[i-1]--,flag = i,继续按照这个逻辑向前遍历。
代码:
class Solution {
public:
int monotoneIncreasingDigits(int n) {
string str = to_string(n);
int flag = str.size();
for(int i = str.size()-1;i>0;i--)
{
if(str[i]<str[i-1])
{
str[i-1]--;
flag = i;
}
}
for(int i = flag;i<str.size();i++)
{
str[i] = '9';
}
return stoi(str);
}
};
968.监控二叉树
给定一个二叉树,我们在树的节点上安装摄像头。
节点上的每个摄影头都可以监视其父对象、自身及其直接子对象。
计算监控树的所有节点所需的最小摄像头数量。
示例 1:
输入:[0,0,null,0,0] 输出:1 解释:如图所示,一台摄像头足以监控所有节点。
示例 2:
输入:[0,0,null,0,null,0,null,null,0] 输出:2 解释:需要至少两个摄像头来监视树的所有节点。 上图显示了摄像头放置的有效位置之一。
思路:
我们采用后续遍历,递归终止条件if(root==NULL),假设这几个状态,若返回0表示无覆盖,若返回1表示有摄像头,若返回2表示有覆盖。
有以下几种情况:
if(left==2&&right==2) return 0;//表示左右结点是有覆盖的状态,父节点是无覆盖的状态
if(left==0||right==0) return 1;//表示左右结点至少有一个是无覆盖的状态,父节点应该放摄像头
/*
包含以下情况:
left==0&&right==0;
left==0&&right==1;
left==0&&right==2;
left==1&&right==0;
left==2&&right==0;
*/
if(left==1||right==1);//表示左右结点至少有一个有摄像头
/*
包含以下情况:
left==1&&right==1;
left==1&&right==2;
left==2&&right==2;
*/
最后判断头结点的左右结点的返回值情况,有可能左右结点都是有覆盖的情况,这样得另加一个摄像头。
代码:
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
* };
*/
class Solution {
public:
int result = 0;
int treaval(TreeNode* root){
if(root==NULL) return 2;
int left = treaval(root->left);
int right = treaval(root->right);
if(left==2&&right==2) return 0;
if(left==0||right==0)
{
result++;
return 1;
}
if(left==1||right==1) return 2;
return -1;
}
int minCameraCover(TreeNode* root) {
if(treaval(root)==0)result++;
return result;
}
};
还有很多瑕疵,还需继续坚持!