会员题-力扣408-有效单词缩写

有效单词缩写

字符串可以用 缩写 进行表示,缩写 的方法是将任意数量的 不相邻 的子字符串替换为相应子串的长度。例如,字符串 "substitution" 可以缩写为(不止这几种方法):

"s10n" ("s ubstitutio n")

"sub4u4" ("sub stit u tion")

"12" ("substitution")

"su3i1u2on" ("su bst i t u ti on")

"substitution" (没有替换子字符串)

下列是不合法的缩写:

"s55n" ("s ubsti tutio n",两处缩写相邻)

"s010n" (缩写存在前导零)

"s0ubstitution" (缩写是一个空字符串)

给你一个字符串单词 word 和一个缩写 abbr ,判断这个缩写是否可以是给定单词的缩写。

子字符串是字符串中连续的非空字符序列。

c 复制代码
class Solution {
public:
    bool validWordAbbreviation(string word, string abbr) {
        int abbrsize= abbr.size(),wordsize=word.size();
        //游标,记录当前判断的位置
        int abbrLen=0; 

        //num记录字母间的数字大小
        int num=0; 

        for (int i = 0; i < abbrsize; ++i){
            if (abbr[i]>='a' && abbr[i]<='z'){
                abbrLen+=num+1; //数字加字母的长度
                num=0;

                //越界或者单词对应位置不相同,直接返回false
                if (abbrLen>wordsize || abbr[i]!=word[abbrLen-1]) return false;
            }
            else{ 
                //遇到了前导0:当前缩写位置上的字符为0,并且num=0
                if (!num && abbr[i]=='0') return false;

                num=num*10+abbr[i]-'0'; //连续遇到两个数字,要拼接起来
            }
        }
        return abbrLen+num==wordsize;
    }
};
相关推荐
sheeta19981 小时前
LeetCode 每日一题笔记 日期:2026.05.08 题目:3629. 素数跳跃最小次数
笔记·算法·leetcode
叼烟扛炮1 小时前
C++ 知识点08 类与对象
开发语言·c++·算法·类和对象
米粒12 小时前
力扣算法刷题 Day 63 Bellman_ford 算法
数据库·算法·leetcode
IT大白鼠8 小时前
AIGC性能的关键瓶颈:算力、数据、算法三者如何互相制约?
算法·aigc
白雪茫茫9 小时前
监督学习、半监督学习、无监督学习算法详解
python·学习·算法·ai
FengyunSky9 小时前
浅析 空间频率响应 SFR 计算
算法
树下水月9 小时前
PHP 一种改良版的雪花算法
算法·php·dreamweaver
一只数据集10 小时前
全尺寸人形机器人灵巧手力觉触觉数据集-2908条ROSbag数据覆盖14大应用场景深度解析
大数据·人工智能·算法·机器人
罗西的思考11 小时前
【GUI-Agent】阿里通义MAI-UI 代码阅读(2)--- 实现
人工智能·算法·机器学习
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ11 小时前
通过java后端代码来实现给word内容补充格式文本内容控件,以及 设置控件的标记和标题
java·c#·word