【LeetCode】1544. 整理字符串、LCP 44. 开幕式焰火
作者:小卢
专栏:《Leetcode》
喜欢的话:世间因为少年的挺身而出,而更加瑰丽。 ——《人民日报》
目录
1544. 整理字符串
LCP 44. 开幕式焰火
1544. 整理字符串
1544. 整理字符串
题目描述:
给你一个由大小写英文字母组成的字符串 s 。
一个整理好的字符串中,两个相邻字符 s[i] 和 s[i+1],其中 0<= i <= s.length-2 ,要满足如下条件:
若 s[i] 是小写字符,则 s[i+1] 不可以是相同的大写字符。
若 s[i] 是大写字符,则 s[i+1] 不可以是相同的小写字符。
请你将字符串整理好,每次你都可以从字符串中选出满足上述条件的 两个相邻 字符并删除,直到字符串整理好为止。
请返回整理好的 字符串 。题目保证在给出的约束条件下,测试样例对应的答案是唯一的。
注意:空字符串也属于整理好的字符串,尽管其中没有任何字符。
示例:
思路:
这里不可以使用暴力,过不去的,血泪教训!!!
这里可以利用栈,当栈为空时or两个字符不互为大小字母时,入栈
否则出栈。
代码:
char * makeGood(char * s){
if(strlen(s)==1||strlen(s)==0) return s;//防止单字符和空字符的字符串的情况
int i=0;
int top=0;//模拟出栈入栈
for(int i=0;s[i]!='\0';i++)
{
if(top==0||abs(s[top-1]-s[i])!=32)
s[top++]=s[i];
else
top--;//出栈,这里会覆盖,不会出现leeetcode的情况
}
s[top]='\0';
return s;
}
LCP 44. 开幕式焰火
LCP 44. 开幕式焰火
题目描述:
「力扣挑战赛」开幕式开始了,空中绽放了一颗二叉树形的巨型焰火。
给定一棵二叉树 root 代表焰火,节点值表示巨型焰火这一位置的颜色种类。请帮小扣计算巨型焰火有多少种不同的颜色。
示例:
思路:
这里我们利用前序遍历的思路,然后用一个数组记录出现的数字(颜色)然后来这个数组来判断是否count++
代码:
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* };
*/
void dfs(struct TreeNode* root,int *arr,int*count)
{
if(root==NULL)
return;
//前序遍历
if(arr[root->val]==0)//之前没有这个颜色(数字)的烟火
{
(*count)++;
arr[root->val]=1;
}
dfs(root->left,arr,count);
dfs(root->right,arr,count);
}
int numColor(struct TreeNode* root){
int arr[1001]={0};
int count=0;
dfs(root,arr,&count);
return count;
}