给定两个字符串str1和str2,查找str2在str1中出现的位置

2023-05-16

给定string str1和string str2,编写一个库函数,返回str2在str1中的位置。

如:str1为"ABCDLANCEXYZ",str2为"LANCE",则返回位置5。如果没有找到,返回-1。(起始位置从1开始)

// findSubStrPosition.c
#include <stdio.h>

int findSubStrPosition(const char *pStr1, const char *pStr2)
{
    int len1 = strlen(pStr1);
    int len2 = strlen(pStr2);
    if (len1 < len2)
        return -1;
    int i = 0;
    for ( ; i < len1; i++)
    {
        int j = 0;
        if (pStr1[i] != pStr2[j])
            continue;
        while(j < len2 & i+j < len1)
        {
            j++;
            if (pStr1[i+j] != pStr2[j])
                break;
        }
        if (j == len2)
            return i+1 ; // start 1
    }
    return -1;
}

int main()
{
    const char *str1 = "ABCDLANCEXYZ";
    const char *str2 = "LANCE";
    int position = 0;
    position = findSubStrPosition(str1, str2);
    printf("the substring position is %d\n", position);
    return 0;
}

// findSubStrPosition.cpp
#include <iostream>
#include <string>

bool isSubstr(std::string str1, std::string str2)
{
    if (str1.length() < str2.length())
        return false;
    int index = 0;
    while(index < str2.length())
    {
        if(str2[index] == str1[index])
            index++;
        else
            return false;
    }
    return true;
}

int findSubStrPosition(std::string str1, std::string str2)
{
    int index = 0;
    while(index < (str1.length() - str2.length()))
    {
        if (isSubstr(str1.substr(index), str2))
            return index + 1;   // start 1
        else
            index++;
    }
    return -1;
}

int main()
{
    std::string str1 = "ABCDLANCEXYZ";
    std::string str2 = "LANCE";
    int position = 0;
    position = findSubStrPosition(str1, str2);
    std::cout<< "the substring position is "<< position << std::endl;
    //std::cout<< "the substring position is "<< str1.find(str2) << std::endl;
    return 0;
}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

给定两个字符串str1和str2,查找str2在str1中出现的位置 的相关文章

随机推荐

  • 使用pytorch预训练模型分类与特征提取

    pytorch pytorch v0 1 这个是早期版本了 应该是深度学习框架里面比较好使用的了 xff0c 相比于tensorflow xff0c mxnet 可能在用户上稍微少一点 xff0c 有的时候出问题不好找文章 下面就使用pyt
  • 深度学习训练中为什么要将图片随机剪裁(random crop)

    图像分类中 xff0c 深度学习训练时将图片随机剪裁 xff08 random crop xff09 已经成为很普遍的数据扩充 xff08 data augmentation xff09 方法 xff0c 随机剪裁不但提高了模型精度 xff
  • pytorch: grad can be implicitly created only for scalar outputs

    这个错误很早就遇到过但是没看到网上叙述清楚的 xff0c 这里顺便写一下 这里贴一下autograd grad 的注释 grad outputs inputs grad outputs 61 None retain graph 61 Non
  • 【经验】无线传输——空中速率

    1 简述 空中速率表示无线 xff08 在空气中的 xff09 通讯速率 xff0c 也叫空中波特率 信道速率 xff0c 单位bps xff08 秒传输的比特数 xff09 2 速率高低 空中速率高 xff0c 则数据传输速度快 xff0
  • 解决Win7的一个毛病——睡眠失效(只关闭显示器,不关主机)

    1 按下windows徽标键 xff0c 输入regedit xff0c 进入注册表 xff1b 2 进入注册表的HKEY LOCAL MACHINE SYSTEM CurrentControlSet Control Session Man
  • 【视频】海康摄像头、NVR网络协议简介

    目录 郭老二博文之 图像视频汇总 1 软硬件整体架构 2 涉及的网络协议 3 协议简介 3 1 海康私有协议 设备发现SADP 进行设备的发现 激活 修改网络参数 忘记密码等 SDK 4200 系统平台的接入前端设备 协议不对外开放 但对外
  • 十分钟读懂游戏研发、发行、渠道那些事儿

    国庆在家写了7天东西 xff0c 实在是累得够呛 我重新梳理了一下以前做过的事儿 xff0c 正好把去年年初发到腾讯GAD的文章拿过来做个修改补充 xff0c 算是再做个总结吧 这篇文章主要是介绍游戏行业的上下游产业链有哪些玩家 xff0c
  • pomelo源码解析--新建项目(cli工具: pomelo)

    pomelo怎么新建项目 官方文档 1 安装pomelo 2 新建项目HelloWorld 我简单整理了下创建新项目关键步骤 xff1a 安装pomelo 方式一 xff1a npm install pomelo g 方式二 xff1a g
  • pomelo源码解析--启动项目(pomelo start)

    我们知道启动pomelo服务器是命令pomelo start xff0c 那执行pomelo start到底都做了些什么 xff1f 服务器之间是怎么连接的 xff1f 客户端是怎么给服务器发消息的 xff1f 下面我们通过源码一步步来展开
  • 博客迁移 https://cxx001.gitee.io

    博客新地址 xff1a https cxx001 gitee io
  • OpenGL--粒子系统

    理论基础 1 xff0c 粒子系统的基本思想是用许多形状简单且赋予生命的微小粒子作为基本元素来表示物体 一般由点或很小的多边形通过纹理贴图表示 xff0c 侧重于物体的总体形态和特征的动态变化 把物体定义为许多不规则 xff0c 随机分布的
  • Cocos2dx-- 聊天系统之富文本(RichText)与字体对齐

    前言 游戏开发中我们一般都会有聊天系统 xff0c 我们可以同时或单独发文字 xff0c 图片 xff0c 表情 xff0c 超链接等信息的文本即称为富文本 如下图所示 xff1a 我使用的是cocos 3 4引擎版本里的RichText富
  • OpenGL--天空盒

    理论基础 1 xff0c 目前虚拟场景中天空建模常用的方法有天空顶 SkyDome 半球形 和天空盒 SkyBox 长方体 两种方法 其本质都是摄像机处在一个盒子中间 xff0c 这个盒子通过纹理贴图形成的虚拟世界场景 其中天空盒绘制技术非
  • OpenGL--使用Shader

    创建Shader 关于在OpenGL中怎么创建Shader这个在很早我博客中就有过详细介绍了 这里全当复习 xff0c 温故而知新 xff5e 在OpenGL中 xff0c 存在Program和Shader两个概念 xff0c Progra
  • 轻松学习CAN总线系列---3.CAN数据遵循的格式

    CAN帧 帧类型数据帧远程帧寻址CRC和应答位填充 帧类型 数据帧 xff08 Data frame xff09 为传输用户数据 xff0c ISO 11898 1定义了数据帧 数据帧可以传输的最大有效负载为八个字节 xff0c 即数据场
  • 无法解析的外部符号 "public: virtual struct CRuntimeClass

    无法解析的外部符号 34 public virtual struct CRuntimeClass thiscall CMessageBox GetRuntimeClass void const 34 以下原因是会引起上述错误的 xff1a
  • Qt控件美化 用好CSS/QSS可视化工具

    一 CSS概念 级联样式表 CSS 包含应用于网页中的元素的样式规则 CSS 样式定义元素的显示方式以及元素在页中的放置位置 可以创建一个通用规则 xff0c 只要 Web 浏览器遇到一个元素实例 xff0c 或遇到一个分配给某个特定样式类
  • c/c++中的struct和class的区别

    主要有两种情况 xff1a 1 C语言中的struct和c 43 43 中的class区别 2 c 43 43 中的struct和c 43 43 中的class的区别 下面分别介绍 xff1a 1 C语言中的struct和c 43 43 中
  • Linux应用层对串口的使用操作

    在Linux中串口作为字符设备 xff0c 设备节点在 dev 目录下 xff0c 使用普通的open xff0c close xff0c write和read等系统调用即可使用 这其中会涉及到一些串口的基本属性的设置 xff0c 如 波特
  • 给定两个字符串str1和str2,查找str2在str1中出现的位置

    给定string str1和string str2 xff0c 编写一个库函数 xff0c 返回str2在str1中的位置 如 xff1a str1为 34 ABCDLANCEXYZ 34 xff0c str2为 34 LANCE 34 x