c语言--力扣简单题目(最后一个单词的长度)讲解

题目如下:

给你一个字符串 s,由若干单词组成,单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。

单词 是指仅由字母组成、不包含任何空格字符的最大

子字符串。

示例 1:

输入:s = "Hello World" 输出:5 解释:最后一个单词是"World",长度为 5。

示例 2:

输入:s = " fly me to the moon " 输出:4 解释:最后一个单词是"moon",长度为 4。

示例 3:

输入:s = "luffy is still joyboy" 输出:6 解释:最后一个单词是长度为 6 的"joyboy"。

代码如下;

复制代码
char ch;
int x = 1;
int n = 0;
printf("请输入单词");
while ((ch = getchar()) != '\n') {
    if (ch == ' ') {
        x = 0;
        continue;
    }
    if (x == 0) {
        n = 0;
        x = 1;
    }
    if (ch != ' ') {
        n += 1;
    }
}
printf("%d", n);
return 0;

这里我们的思路是让x作为判断是否为下一个单词,如果x为0,那么就代表下一个单词开始,并且让n也为0,用来记载单词数量。

当我们检测到最后一个单词的时候,因为没有下一个单词了,所以n就不会重置为0,这时只需要打印n的就可以了。

相关推荐
风筝在晴天搁浅23 分钟前
LeetCode CodeTop 82.删除排序链表中的重复元素Ⅱ
算法·leetcode·链表
1892280486125 分钟前
NV114固态MT29F16T08EWLEHD6-MES:E
人工智能·算法·缓存·性能优化
2601_9516457426 分钟前
C语言基础语法,分支语句
c语言·运算符·if语句·switch语句·分支语句
dtq042431 分钟前
C语言刷题函数1-判断素数(分支语句,函数两种方法)
c语言·开发语言·学习
Tairitsu_H35 分钟前
[LC优选算法#4] 滑动窗口 | 串联所有单词的⼦串 | 最⼩覆盖⼦串
c++·算法·滑动窗口
devilnumber36 分钟前
Java 二分查找(二分算法)详解 + 实战运用 + 核心坑点
java·开发语言·算法
洛水水38 分钟前
【力扣100题】84.字符串解码
算法·leetcode·职场和发展
AI科技星1 小时前
第四卷:橡皮泥江湖(拓扑学)
c语言·开发语言·网络·量子计算·agi·拓扑学
2601_951643881 小时前
关于C语言中getchar()的详细使用
c语言·输入输出·getchar()·eof·文件结束符
小七在进步1 小时前
数据结构:线性表之单链表
c语言·数据结构