LeetCode 2255统计是给定字符串前缀的字符串数目

问题描述:

在字符串处理的编程任务中,经常会遇到判断一个字符串数组中的元素是否为另一个字符串前缀的情况。例如,给定一个字符串数组 words 和一个字符串 s,且 words[i] 和 s 都只包含小写英文字母,我们需要找出 words 中有多少个字符串是 s 的前缀。这一问题在文本分析、搜索引擎优化以及数据预处理等领域都有实际应用场景。

代码实现剖析:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>// 函数用于统计words数组中是字符串s前缀的字符串数目
int countPrefixes(char** words, int wordsSize, char* s) {int count = 0;// 遍历字符串数组wordsfor (int i = 0; i < wordsSize; i++) {char* word = words[i];int j = 0;// 逐个比较字符,直到不匹配或到达字符串末尾while (word[j]!= '\0' && s[j]!= '\0' && word[j] == s[j]) {j++;}// 如果word遍历完,说明是前缀if (word[j] == '\0') {count++;}}return count;
}int main() {// 定义示例的字符串数组wordschar* words[] = {"a", "ab", "abc", "abcd"};int wordsSize = sizeof(words) / sizeof(words[0]);// 定义目标字符串schar s[] = "abcde";// 调用函数进行统计int result = countPrefixes(words, wordsSize, s);printf("在给定的字符串数组中,是目标字符串前缀的字符串数目为: %d\n", result);return 0;
}

countPrefixes函数部分:

  1. 首先定义了一个变量count并初始化为0,用于记录满足是前缀条件的字符串个数。

  2. 接着通过for循环遍历传入的字符串数组words,对于每个字符串(用words[i]获取当前字符串指针,赋值给word):

    • 初始化一个索引变量j0,进入while循环开始逐个比较当前字符串word和目标字符串s的字符。只要words当前字符都不为'\0'(表示字符串未结束)且对应字符相等,就继续向后比较下一个字符(通过j自增实现)。

    • while循环结束后,如果发现当前字符串word已经到达末尾(即word[j] == '\0'),那就说明words的前缀,此时将count的值加1

  3. 最后函数返回count的值,也就是统计出的是前缀的字符串个数。

 main函数部分:

  1. 定义了一个示例的字符串数组words,里面包含了几个测试用的字符串,同时定义了目标字符串s

  2. 通过sizeof操作符计算出字符串数组words的元素个数(即wordsSize)。

  3. 调用countPrefixes函数并传入words数组、wordsSize以及目标字符串s,将返回的结果存储在result变量中。

  4. 最后使用printf函数输出统计结果,告知用户在给定的字符串数组中,是目标字符串前缀的字符串具体数目是多少。

总结与拓展

通过这个简单而实用的函数,我们展示了 C 语言在字符串处理方面的能力。这种前缀统计的功能在很多实际应用中都非常有用,比如在搜索引擎的关键词匹配、文本数据的预处理等场景。当然,我们还可以进一步拓展这个功能,例如统计每个前缀的出现次数并存储在一个数据结构中,或者对字符串数组进行预处理以提高查找效率等。希望读者能够深入理解这个代码示例,并尝试在自己的项目中灵活运用类似的字符串处理技巧。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/889987.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM系列之内存区域

每日禅语 有一位年轻和尚&#xff0c;一心求道&#xff0c;多年苦修参禅&#xff0c;但一直没有开悟。有一天&#xff0c;他打听到深山中有一古寺&#xff0c;住持和尚修炼圆通&#xff0c;是得道高僧。于是&#xff0c;年轻和尚打点行装&#xff0c;跋山涉水&#xff0c;千辛万…

大腾智能CAD:国产云原生三维设计新选择

在快速发展的工业设计领域&#xff0c;CAD软件已成为不可或缺的核心工具。它通过强大的建模、分析、优化等功能&#xff0c;不仅显著提升了设计效率与精度&#xff0c;还促进了设计思维的创新与拓展&#xff0c;为产品从概念构想到实体制造的全过程提供了强有力的技术支持。然而…

css常用属性有哪些

在上篇文章我们知道了利用css选择器来对HTML进行简单装饰&#xff0c;就像做word文档一样&#xff0c;需要对哪一段落修改格式&#xff0c;就需要先选中&#xff0c;css选择器就是这意思。这格式如何修改&#xff0c;怎么放大字体&#xff0c;怎么加粗&#xff0c;怎么修改背景…

leetcode 3195.包含所有1的最小矩形面积I

1.题目要求: 2.解题步骤: class Solution { public:int minimumArea(vector<vector<int>>& grid) {//设置二维数组deque<deque<int>> row_distance;for(int i 0;i < grid.size();i){//遍历数组&#xff0c;把每行头部1的小标和尾部1的下标代…

搭建Tomcat(三)---重写service方法

目录 引入 一、在Java中创建一个新的空项目&#xff08;初步搭建&#xff09; 问题&#xff1a; 要求在tomcat软件包下的MyTomcat类中编写main文件&#xff0c;实现在MyTomcat中扫描myweb软件包中的所有Java文件&#xff0c;并返回“WebServlet(url"myFirst")”中…

创建线程 ---- 实例

1、C语言 创建线程 执行2个不同的函数&#xff1a; #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <pthread.h>// 第一个线程要执行的函数 void* function1(void* arg) {printf("Function 1 is running\n");// 执行…

使用mybatisplus的逆向工程自动生成数据库中表对应的实体类、mapper、service、serviceImpl、controller等文件

使用mybatisplus的逆向工程自动生成数据库中表对应的实体类、mapper、service、serviceImpl、controller等文件 详细流程如下&#xff1a; 1、引入依赖 <dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-sta…

Linux介绍与安装CentOS 7操作系统

什么是操作系统 操作系统&#xff0c;英⽂名称 Operating System&#xff0c;简称 OS&#xff0c;是计算机系统中必不 可少的基础系统软件&#xff0c;它是 应⽤程序运⾏以及⽤户操作必备的基础环境 ⽀撑&#xff0c;是计算机系统的核⼼。 操作系统的作⽤是管理和控制计算机系…

【Linux】深入理解进程信号机制:信号的产生、捕获与阻塞

&#x1f3ac; 个人主页&#xff1a;谁在夜里看海. &#x1f4d6; 个人专栏&#xff1a;《C系列》《Linux系列》《算法系列》 ⛰️ 时间不语&#xff0c;却回答了所有问题 目录 &#x1f4da;前言 &#x1f4da;一、信号的本质 &#x1f4d6;1.异步通信 &#x1f4d6;2.信…

【西门子PLC.博途】——面向对象编程及输入输出映射FC块

当我们做面向对象编程的时候&#xff0c;需要用到输入输出的映射。这样建立的变量就能够被复用&#xff0c;从而最大化利用了我们建立的udt对象。 下面就来讲讲映射是什么。 从本质上来说&#xff0c;映射就是拿实际物理对象对应程序虚拟对象&#xff0c;假设程序对象是I0.0&…

WebRTC服务质量(04)- 重传机制(01) RTX NACK概述

WebRTC服务质量&#xff08;01&#xff09;- Qos概述 WebRTC服务质量&#xff08;02&#xff09;- RTP协议 WebRTC服务质量&#xff08;03&#xff09;- RTCP协议 WebRTC服务质量&#xff08;04&#xff09;- 重传机制&#xff08;01) RTX NACK概述 WebRTC服务质量&#xff08;…

MySQL索引的理解

MySQL与磁盘的交互 根据冯诺依曼结构体系&#xff0c;我们知道我们任何上层的应用想要去访问磁盘就必须要通过内存来访问&#xff0c;MySQL作为一款储存数据的服务&#xff0c;肯定是很多时间要用来访问磁盘。而大量访问磁盘一定会影响运行效率的在innoDB的存储引擎下为了减少…

spring集成ehcache

目录 一、前言二、使用ehcache注解方式2.1、配置2.2、使用示例三、直接读取xml方式3.1、配置3.2、使用示例3.3、结果说明一、前言 问题背景:一些业务场景中,一些数据往往是长期不变更,但数据使用较多。为了满足系统性能需要,可以借助本地缓存去使用,保证同一个JVM实例只保…

分布式全文检索引擎ElasticSearch-数据的写入存储底层原理

一、数据写入的核心流程 当向 ES 索引写入数据时&#xff0c;整体流程如下&#xff1a; 1、客户端发送写入请求 客户端向 ES 集群的任意节点&#xff08;称为协调节点&#xff0c;Coordinating Node&#xff09;发送一个写入请求&#xff0c;比如 index&#xff08;插入或更…

前端解析超图的iserver xml

前端解析超图的iserver xml const res await axios.get(url)const xmlDom new DOMParser().parseFromString(res.data, text/xml);// 获取versionconst version xmlDom.getElementsByTagNameNS(*, ServiceTypeVersion)[0].textContent// 获取layerconst layerDom xmlDom.ge…

Maven 生命周期

文章目录 Maven 生命周期- Clean 生命周期- Build 生命周期- Site 生命周期 Maven 生命周期 Maven 有以下三个标准的生命周期&#xff1a; Clean 生命周期&#xff1a; clean&#xff1a;删除目标目录中的编译输出文件。这通常是在构建之前执行的&#xff0c;以确保项目从一个…

Android Studio AI助手---Gemini

从金丝雀频道下载最新版 Android Studio&#xff0c;以利用所有这些新功能&#xff0c;并继续阅读以了解新增内容。 Gemini 现在可以编写、重构和记录 Android 代码 Gemini 不仅仅是提供指导。它可以编辑您的代码&#xff0c;帮助您快速从原型转向实现&#xff0c;实现常见的…

倒排单词C++

描述 编写程序&#xff0c;读入一行英文(只包含字母和空格&#xff0c;单词间以单个空格分隔)&#xff0c;将所有单词的顺序倒排并输出&#xff0c;依然以单个空格分隔。 输入描述 输入为一个字符串&#xff08;字符串长度至多为100&#xff09;。 输出描述 共一行&#xff0c;…

#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍04-盲SQL注入(Blind SQL Injection)

免责声明 本教程仅为合法的教学目的而准备&#xff0c;严禁用于任何形式的违法犯罪活动及其他商业行为&#xff0c;在使用本教程前&#xff0c;您应确保该行为符合当地的法律法规&#xff0c;继续阅读即表示您需自行承担所有操作的后果&#xff0c;如有异议&#xff0c;请立即停…

Scala 的迭代器

迭代器定义&#xff1a;迭代器不是一种集合&#xff0c;它是一种用于访问集合的方法。 迭代器需要通过集合对应的迭代器调用迭代器的方法来访问。 支持函数式编程风格&#xff0c;便于链式操作。 创建一个迭代器&#xff0c;相关代码如下&#xff1a; object Test {def mai…