Leecode刷题C语言之按键变更的次数

执行结果:通过

执行用时和内存消耗如下:

复制代码
int countKeyChanges(char* s) {
    int count=0,i=0;
    while(s[i]!='\0'){
        if((s[i]!=s[i+1])&&(s[i]!=(s[i+1]+32))&&(s[i]!=(s[i+1]-32))&&s[i+1]!=0)count++;
        i++;
    }
    return count;
}

解题思路:

  1. 初始化变量
    • count:用于记录键变化的次数,初始化为0。
    • i:用于遍历字符串的索引,初始化为0。
  2. 遍历字符串
    • 使用 while 循环遍历字符串,直到遇到字符串的结束符 \0
  3. 检查相邻字符
    • 在每次循环中,检查当前字符 s[i] 和下一个字符 s[i+1] 是否满足以下条件之一:
      • s[i] != s[i+1]:两个字符不相同。
      • s[i] != (s[i+1] + 32):当前字符不是下一个字符的小写形式(假设ASCII码,小写字母比对应大写字母大32)。
      • s[i] != (s[i+1] - 32):当前字符不是下一个字符的大写形式。
      • s[i+1] != 0:确保 s[i+1] 不是字符串结束符(虽然这个条件在 while 循环的条件中已经隐含,但这里再次检查可以避免访问未定义内存)。
    • 如果上述所有条件都不满足,说明两个字符要么相同,要么是大小写关系(例如,'A' 和 'a'),此时不计入键变化次数。
    • 如果上述任一条件满足,说明发生了键变化,将 count 增加1。
  4. 索引递增
    • 每次循环结束时,将索引 i 增加1,以移动到下一个字符。
  5. 返回结果
    • 当遍历完整个字符串后,返回 count,即总的键变化次数。

注意 :代码中有一个小细节需要注意,即 (s[i+1]!=0) 这个条件在 while 循环的条件中已经通过 s[i]!='\0' 隐含地确保了 s[i+1] 的存在(除非 s[i] 是字符串的最后一个字符),因此这个条件实际上是多余的,可以省略。

相关推荐
小白程序员成长日记31 分钟前
2025.11.21 力扣每日一题
算法·leetcode·职场和发展
小年糕是糕手1 小时前
【C++】C++入门 -- inline、nullptr
linux·开发语言·jvm·数据结构·c++·算法·排序算法
高洁011 小时前
具身智能-普通LLM智能体与具身智能:从语言理解到自主行动
人工智能·深度学习·算法·aigc·知识图谱
星期天22 小时前
3.2联合体和枚举enum,还有动态内存malloc,free,calloc,realloc
c语言·开发语言·算法·联合体·动态内存·初学者入门·枚举enum
Andy2 小时前
回文子串数目--动态规划算法
算法·动态规划
sin_hielo2 小时前
leetcode 1930
算法·leetcode
塞北山巅2 小时前
相机自动曝光(AE)核心算法——从参数调节到亮度标定
数码相机·算法
聆风吟º2 小时前
【数据结构入门手札】算法核心概念与复杂度入门
数据结构·算法·复杂度·算法的特性·算法设计要求·事后统计方法·事前分析估算方法
vir023 小时前
密码脱落(最长回文子序列)
数据结构·c++·算法
福尔摩斯张3 小时前
二维数组详解:定义、初始化与实战
linux·开发语言·数据结构·c++·算法·排序算法