58. 最后一个单词的长度;709. 转换成小写字母;682. 棒球比赛;657. 机器人能否返回原点

文章讨论了三个编程问题:计算字符串中最后一个单词的长度,将字符串中的大写字母转换为小写,以及模拟棒球比赛中的得分规则。通过遍历和逻辑判断解决这些与字符串处理和计数相关的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

58. 最后一个单词的长度

给你一个字符串 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”。

题解

思路:(反向遍历)时间复杂度为O(n)

1.从后往前遍历,找到非空白字符的位置

2.开始计数,直到所遇字符为空白字符,返回计数值

代码:

 
class Solution {
 public:
     int lengthOfLastWord(string s) {
         int index = s.size() - 1;
         while (s[index] == ' ') --index;
         unsigned int length = 0;
         while (index >= 0 && s[index] != ' ') 
         {
             ++length;
             --index;
         }
         return length;
     }
 };

709. 转换成小写字母

给你一个字符串 s ,将该字符串中的大写字母转换成相同的小写字母,返回新的字符串。

示例 1:

 输入:s = "Hello"
 输出:"hello"

示例 2:

 输入:s = "here"
 输出:"here"

示例 3:

 输入:s = "LOVELY"
 输出:"lovely"

题解

思路(遍历字符串,判断每个字符是否为小写,是小写则转为大写,时间复杂度为O(n))

  1. 使用API,tolower()

  2. 自己实现tolower()

代码1

 
class Solution {
 public:
     string toLowerCase(string s) {
         for (auto& ch: s) {
              ch = tolower(ch);
         }
         return s;
     }
 };

代码2

 
class Solution {
 public:
     string toLowerCase(string s) {
         for (char& ch: s) {
             if (ch >= 65 && ch <= 90) {
                 ch += 32;
               //ch |= 32;//或运算替代加法运算
             }
         }
         return s;
     }
 };
 ​

682. 棒球比赛

你现在是一场采用特殊赛制棒球比赛的记录员。这场比赛由若干回合组成,过去几回合的得分可能会影响以后几回合的得分。

比赛开始时,记录是空白的。你会得到一个记录操作的字符串列表 ops,其中 ops[i] 是你需要记录的第 i 项操作,ops 遵循下述规则:

  1. 整数 x - 表示本回合新获得分数 x

  2. "+" - 表示本回合新获得的得分是前两次得分的总和。题目数据保证记录此操作时前面总是存在两个有效的分数。

  3. "D" - 表示本回合新获得的得分是前一次得分的两倍。题目数据保证记录此操作时前面总是存在一个有效的分数。

  4. "C" - 表示前一次得分无效,将其从记录中移除。题目数据保证记录此操作时前面总是存在一个有效的分数。

请你返回记录中所有得分的总和。

示例 1:

 输入:ops = ["5","2","C","D","+"]
 输出:30
 解释:
 "5" - 记录加 5 ,记录现在是 [5]
 "2" - 记录加 2 ,记录现在是 [5, 2]
 "C" - 使前一次得分的记录无效并将其移除,记录现在是 [5].
 "D" - 记录加 2 * 5 = 10 ,记录现在是 [5, 10].
 "+" - 记录加 5 + 10 = 15 ,记录现在是 [5, 10, 15].
 所有得分的总和 5 + 10 + 15 = 30

示例 2:

 输入:ops = ["5","-2","4","C","D","9","+","+"]
 输出:27
 解释:
 "5" - 记录加 5 ,记录现在是 [5]
 "-2" - 记录加 -2 ,记录现在是 [5, -2]
 "4" - 记录加 4 ,记录现在是 [5, -2, 4]
 "C" - 使前一次得分的记录无效并将其移除,记录现在是 [5, -2]
 "D" - 记录加 2 * -2 = -4 ,记录现在是 [5, -2, -4]
 "9" - 记录加 9 ,记录现在是 [5, -2, -4, 9]
 "+" - 记录加 -4 + 9 = 5 ,记录现在是 [5, -2, -4, 9, 5]
 "+" - 记录加 9 + 5 = 14 ,记录现在是 [5, -2, -4, 9, 5, 14]
 所有得分的总和 5 + -2 + -4 + 9 + 5 + 14 = 27

示例 3:

 输入:ops = ["1"]
 输出:1

题解

思路

根据规则遍历字符串,将对应字符转为数字使用stoi(),累计求和,这里需要用到一个数组保存每一次的结果。

代码

 class Solution {
 public:
     int calPoints(vector<string>& ops) {
         vector<int> res(ops.size());
         int ans = 0;
         auto it { res.begin() };
         for (const auto& i : ops)
         {
             switch(i[0])
             {
                 case '+': *it++ = *(it - 1) + *(it - 2);break;
                 case 'D': *it++ = 2 * *(it - 1);break;
                 case 'C': it--;break;
                 default:  *it++ = stoi(i);break;
             }       
         }
         return accumulate(res.begin(), it, 0);
     }
 };

657. 机器人能否返回原点

在二维平面上,有一个机器人从原点 (0, 0) 开始。给出它的移动顺序,判断这个机器人在完成移动后是否在 (0, 0) 处结束

移动顺序由字符串 moves 表示。字符 move[i] 表示其第 i 次移动。机器人的有效动作有 R(右),L(左),U(上)和 D(下)。

如果机器人在完成所有动作后返回原点,则返回 true。否则,返回 false

注意:机器人“面朝”的方向无关紧要。 “R” 将始终使机器人向右移动一次,“L” 将始终向左移动等。此外,假设每次移动机器人的移动幅度相同。

示例 1:

 输入: moves = "UD"
 输出: true
 解释:机器人向上移动一次,然后向下移动一次。所有动作都具有相同的幅度,因此它最终回到它开始的原点。因此,我们返回 true。

示例 2:

 输入: moves = "LL"
 输出: false
 解释:机器人向左移动两次。它最终位于原点的左侧,距原点有两次 “移动” 的距离。我们返回 false,因为它在移动结束时没有返回原点。

题解

思路

遍历字符串moves看对应的操作数目是否相等(有一个上,必有一个下,有一个左,必有一个有),如果相等则返回true,否则返回false;

定义一个数组arr[2] ,如果是'U','L',则arr[0]++,arr[1]++,如果是'D','R',则arr[0]--,arr[1]--,最后判断arr[2]是否为0即可。时间复杂度为O(n)。

代码

class Solution {
public:
    bool judgeCircle(string moves) {
        int arr[2]{0};
        for(const auto& ch : moves)
        {
            switch(ch)
            {
                case 'U': arr[0]++;break;
                case 'L': arr[1]++;break;
                case 'D': arr[0]--;break;
                case 'R': arr[1]--;break;
                default:break;
            }
        }
        return arr[0] == 0 && arr[1] == 0;
    }
};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值