1
力扣 (LeetCode) 刷题,简单题 (第 21 期)
发布于: 2021 年 03 月 06 日
data:image/s3,"s3://crabby-images/1470e/1470ef23730f0c9ac080b62f00460a95ea0df3de" alt="力扣(LeetCode)刷题,简单题(第21期)"
力扣(LeetCode)定期刷题,每期 10 道题,业务繁重的同志可以看看我分享的思路,不是最高效解决方案,只求互相提升。
第 1 题:最大连续 1 的个数
试题要求如下:
data:image/s3,"s3://crabby-images/c06b8/c06b885de786c5482ffe682f633d2213c64b6075" alt=""
回答(C 语言):
int findMaxConsecutiveOnes(int* nums, int numsSize){
int temp = 0;
for(int i = 0,cou = 0; i < numsSize; i++){
if(nums[i] == 1){
cou++;
}
else{
cou = 0;
}
if(cou > temp){
temp = cou;
}
}
return temp;
}
复制代码
运行效率如下所示:
data:image/s3,"s3://crabby-images/ad229/ad22958808f1f27d3b70aef86b0e053c4b7f8119" alt=""
第 2 题:相同的树
试题要求如下:
data:image/s3,"s3://crabby-images/e5b4e/e5b4efd487c13ee6c474a2cdbc27b8a5825537aa" alt=""
回答(C 语言):
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* };
*/
bool isSameTree(struct TreeNode* p, struct TreeNode* q) {
if (p == NULL && q == NULL) {
return true;
} else if (p == NULL || q == NULL) {
return false;
} else if (p->val != q->val) {
return false;
} else {
return isSameTree(p->left, q->left) && isSameTree(p->right, q->right);
}
}
复制代码
运行效率如下所示:
data:image/s3,"s3://crabby-images/0f3d4/0f3d4495bb9f283c583c496774bbe1840e7d0525" alt=""
第 3 题:检查平衡性
试题要求如下:
data:image/s3,"s3://crabby-images/82ec3/82ec3143baa7ee44db7eec7e185695b47d4b859e" alt=""
回答(C 语言):
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* };
*/
#define MAX(a, b) ((a) < (b) ? (b) : (a))
bool CoreFunc(struct TreeNode* root, int* depth)
{
if (NULL == root) {
*depth = 0;
return true;
}
if (NULL == root->left && NULL == root->right) {
*depth = 1;
return true;
}
int left = 0;
int right = 0;
bool ret = CoreFunc(root->left, &left) && CoreFunc(root->right, &right);
int res = left > right ? left - right : right - left;
*depth = MAX(left, right) + 1;
if (ret && res <= 1) {
return true;
} else {
return false;
}
}
bool isBalanced(struct TreeNode* root)
{
if (NULL == root) {
return true;
}
int depth = 0;
return CoreFunc(root, &depth);
}
复制代码
运行效率如下所示:
data:image/s3,"s3://crabby-images/176ff/176ffe9dd4d1f7612166e5cc366f8089a9ad4db6" alt=""
第 4 题:仅仅反转字母
试题要求如下:
data:image/s3,"s3://crabby-images/cfbd2/cfbd25e32ddf1fb0a8744b828cd118850d52cc85" alt=""
回答(C 语言):
char * reverseOnlyLetters(char * S){
int i=0,j=strlen(S)-1;
char tmp=0;
while(i<j){
if(!((S[i] >= 'a' && S[i] <= 'z') || (S[i] >= 'A' && S[i] <= 'Z')))//排除i指向非字母的情况
{
i++;
continue;
}
if(!((S[j] >= 'a' && S[j] <= 'z') || (S[j] >= 'A' && S[j] <= 'Z')))//排除j指向非字母的情况
{
j--;
continue;
}
tmp=S[i];//交换字母
S[i]=S[j];
S[j]=tmp;
i++;
j--;
}
return S;
}
复制代码
运行效率如下所示:
data:image/s3,"s3://crabby-images/5033f/5033fad3dc90a2b225a76599d133a025f01f6a82" alt=""
第 5 题:检测大写字母
试题要求如下:
data:image/s3,"s3://crabby-images/bc9a6/bc9a66f7ad190654563c4272dbc4b7f8e8beac38" alt=""
回答(C 语言):
bool detectCapitalUse(char * word){
int len = strlen(word);
int cnt = 0;
for(int i = 0;i<len;i++){
if((word[i] >= 'A')&&(word[i] <= 'Z'))
cnt++;
}
//对应情况1和情况3
if((cnt == len)||(cnt == 0)){
return true;
}
//对应情况2
else if(((word[0] >= 'A')&&(word[0] <= 'Z')&&(cnt == 1))){
return true;
}
return false;
}
复制代码
运行效率如下所示:
data:image/s3,"s3://crabby-images/d0d92/d0d921cc28e084eabe7fb2718158b90d722fe0a6" alt=""
第 6 题:在区间范围内统计奇数数目
试题要求如下:
data:image/s3,"s3://crabby-images/c1ee4/c1ee4497826ec4d78bb5cbb4f5d39519643c77d8" alt=""
回答(C 语言):
int countOdds(int low, int high){
if((low%2 == 0) && (high%2 ==0)){
return (high-low)/2;
}
return (high-low)/2+1;
}
复制代码
运行效率如下所示:
data:image/s3,"s3://crabby-images/c6da8/c6da898cdf82b1b69bad39f2bd6adc7158bc09ad" alt=""
第 7 题:二分查找
试题要求如下:
data:image/s3,"s3://crabby-images/b9f96/b9f96c90d6ab66f72773854d1917d9dad4f38978" alt=""
回答(C 语言):
int search(int* nums, int numsSize, int target){
int left = 0;
int right = numsSize - 1;
int mid = 0;
while (left <= right) {
mid = left + (right - left) / 2;
if (nums[mid] == target) {
return mid;
} else if (nums[mid] < target) {
left = mid + 1;
} else if (nums[mid] > target) {
right = mid - 1;
}
}
return -1;
}
复制代码
运行效率如下所示:
data:image/s3,"s3://crabby-images/37f6d/37f6d1786c0e942c38a33dd0e9430d34f3f00c10" alt=""
第 8 题:字符串轮转
试题要求如下:
data:image/s3,"s3://crabby-images/10d59/10d59b264cb75e166aef8584bd4792914425f893" alt=""
回答(C 语言):
bool isFlipedString(char* s1, char* s2){
int a = strlen(s1),b = strlen(s2);
if(a != b) return false;
int count = 0;
for(int i = 0; i < a; i++)
{
if(s1[i] == s2[count])
{
count++;
}
}
int m = count;
for(int i = 0; i < a-count; i++)
{
if(s1[i] != s2[m])
{
return false;
}
m++;
}
return true;
}
复制代码
运行效率如下所示:
data:image/s3,"s3://crabby-images/d8e2a/d8e2a8dfab587e0b363fc933cdf441f2cd089be2" alt=""
第 9 题:公交车站间的距离
试题要求如下:
data:image/s3,"s3://crabby-images/f8d51/f8d51611608313acee2bc3a7378867e7831e36cb" alt=""
回答(C 语言):
int distanceBetweenBusStops(int* distance, int distanceSize, int start, int destination){
int dis1 = 0, dis2 = 0;;
int s;
s = start;
while (s != destination) {
dis1 += distance[s];
s = (s + 1) % distanceSize;
}
while (s != start) {
dis2 += distance[s];
s = (s + 1) % distanceSize;
}
return dis1 < dis2 ? dis1 : dis2;
}
复制代码
运行效率如下所示:
data:image/s3,"s3://crabby-images/da3b5/da3b5356545d1ea8ccfdf7c8d12eb84dfaebc8ab" alt=""
第 10 题:有效的括号(2020 哔哩哔哩校招笔试题)
试题要求如下:
data:image/s3,"s3://crabby-images/16f75/16f75ef3a32b4c4f5df04aa1e5aa575be82b6208" alt=""
回答(C 语言):
bool isValid(char * s){
int top = 0;
char* stack = (char*)malloc(strlen(s));
if (s==NULL || strlen(s)<=0) return true;
for (int i = 0; i<strlen(s); i++){
if(s[i]=='(' || s[i]=='{' || s[i]=='['){
stack[top++] = s[i];
}else{
if(--top < 0) return false;
if(s[i]==')' && stack[top] != '(') return false;
if(s[i]=='}' && stack[top] != '{') return false;
if(s[i]==']' && stack[top] != '[') return false;
}
}
if (top > 0) return false;
return true;
}
复制代码
运行效率如下所示:
data:image/s3,"s3://crabby-images/82289/82289e60b4b215a676ac2170b5e6f82617953924" alt=""
划线
评论
复制
发布于: 2021 年 03 月 06 日阅读数: 29
版权声明: 本文为 InfoQ 作者【不脱发的程序猿】的原创文章。
原文链接:【http://xie.infoq.cn/article/f35f69b01b99e4d3a29778858】。文章转载请联系作者。
data:image/s3,"s3://crabby-images/db430/db43046ead3ae8291ab7c434d3ae74b03c11a77e" alt="用户头像"
不脱发的程序猿
关注
【研究方向】物联网、嵌入式、AI、Python 2018.02.09 加入
【公众号】美男子玩编程
评论