首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

魔法 C语言 字符串

题目 小明和他的好朋友小西在玩一个新的游戏,由小西给出一个由小写字母构成的字符串,小明给出另一个比小西更长的字符串,也由小写字母组成,如果能通过魔法转换使小明的和小西的变成同一个,那么他们两个人都会很开心...接下来共T组数据,每组数据第一行输入小西的字符串,第二行输入小明的字符串(数据保证字符串长度不超过1000,小明的的长度大于等于小西的,且所有字符均为小写字母)。...样例输入 2 abba addba 1 d b a dd 0 样例输出 Case #1: happy Case #2: unhappy 碎碎念念 用两个数组把变换方式存进来,设三个字符串...,两个存小西和小明的字符串,另一个用来存变化之后的字符串,思路是将小西和小明的字符串一一比较,相同的字符就直接存进第三个字符串,不同的字符就在变换数组中寻找看看是否存在相应的变换方式,如果有就把变换后的字符存进第三个字符串...,如果没有就不存进去(删除),最后判断第三个字符串是否和小西的字符串相同。

17610
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    C++】STL 容器 - string 字符串操作 ⑦ ( 字符串区间删除 - erase 函数 | 字符串插入 - insert 函数 | 字符串截取 - substr 函数 )

    类的成员函数 , 其作用是 从位置 pos 开始 , 删除长度为 n 的字符串 , 如果 n 的值超过了字符串的长度 , 那么整个字符串都会被删除 ; string& erase(int pos=0..., int n=npos); 参数说明 : pos : 要删除的 字符串 的 起始位置 , 位置从 0 开始计数 ; n : 要删除的字符串的长度 , 默认值为 npos , 表示删除从 pos...; string 类 insert 函数 插入 若干 字符 函数原型 : 该 函数作用是 在字符串的指定位置 pos 插入 n 个字符 c ; 插入后 , 原字符串中位于 pos 位置及其之后的字符会向后移动...; c : 要插入的字符 ; 返回值说明 : 返回一个指向修改后的字符串的引用 ; 2、代码示例 - insert 函数 代码示例 : #include "iostream" using namespace...三、string 字符串截取 - substr 函数 1、string 类 substr 函数原型说明 string 类 substr 函数原型 : 该函数 会截取字符串的一部分 , 并返回一个新的字符串

    1.7K10

    c语言字符串匹配实现_c比较字符串

    字符串匹配原理及实现(C++版) 1. 字符串匹配概念 2. BF 2.1 原理 2.2 代码实现 3. KMP 3.1 原理 3.2 代码实现 4....字符串匹配概念 在查找操作中,我们用到很重要的概念就是字符串匹配,所谓字符串匹配就是在文本中搜索模式是否存在及其存在的位置。下面介绍几种字符串匹配的方法。 2....BF 2.1 原理 BF(暴力法)是一种最简单的字符串匹配算法,匹配过程如下: 文本中的 I 和模式中的 II 实现了匹配。...如果 III 的下一个是 A ,IV 的下一个是 B ,那么匹配失败,模式向后移动一个字符,重新开始字符串匹配。 BF 的特点: 1.模式与文本的匹配是自左向右的进行。...2.一旦模式与文本失配,模式依靠 gs 表向右移动若干个字符。 所谓 BM,就是综合了 BC 和 GS 两个策略进行的字符串匹配算法。

    3.7K30

    C语言字符串函数

    上面说strlen是用来求字符串长度的,而它统计的是\0之前出现的字符的个数,也就是说字符串的结束标志是\0。...1.2.1 指针+整数实现 使用count计数器,统计字符串的长度。 不过在计算字符串长度之前要先断言一下字符串是否为空assert(str != NULL)。...有三种情况,像上图那种,字符串2中q比字符串1中c大,返回的就是一个小于0的数字。 第二种,字符串2比字符串小,返回的就是一个大于0的数字。 第三种,字符串2和字符串相等,返回的就是0。...首先传的两个字符串不能为空,再逐一遍历两个字符串相同位置的字符进行比较。...} 结果显然与分析的一致 10. strerror函数的使用 要学习strerror函数,就得先了解errno: 当库函数调用失败的时候,会讲错误码记录到errno这个变量中 errno是一个C语言的全局变量

    15010

    字符串中查找_cstring查找字符串

    查询 首先,我们来定义两个概念,主和模式。我们在字符串 A 中查找字符串 B,则 A 就是主,B 就是模式。我们把主的长度记为 n,模式长度记为 m。...假设要从主 s = “goodgoogle” 中找到 t = “google” 。...字符串匹配算法的案例 最后我们给出一道面试中常见的高频题目,这也是对字符串匹配算法进行拓展,从而衍生出的问题,即查找出两个字符串的最大公共字串。...假设有且仅有 1 个最大公共。比如,输入 a = “13452439”, b = “123456”。由于字符串 “345” 同时在 a 和 b 中出现,且是同时出现在 a 和 b 中的最长子。...假设字符串 a 的长度为 n,字符串 b 的长度为 m,可见时间复杂度是 n 和 m 的函数。

    3K30

    C语言字符串IO

    引入 详见CPrimerPlus P329 分析常用的处理字符串输入和输出的函数,以及如何结合这几个函数进行优化和设计一些新的处理字符串输入输出的函数。...字符串输入 分配空间 要做的第一件事是分配空间,以存储稍后要读入的字符串。 这意味这要未字符串分配足够的空间,注意计算机在读取字符串时不会计算它的长度。...char name[80]; 2.使用C语言的库函数来分配内存。...使用 gets函数读取整行输入,直到遇到换行符,然后丢弃换行符(与fgets函数区分),存储其他的字符,并在这些字符后面加上一个空字符使其成为一个C字符串。...如果使用%s转换说明,以下一个空白字符(空格、空行、制表符、换行符)作为字符串的结束(字符串不包括空白字符)。

    4.6K10

    C语言字符串函数

    ✨作者:@平凡的人1 ✨专栏:《C语言从0到1》 ✨一句话:凡是过往,皆为序章 ✨说明: 过去无可挽回, 未来可以改变 ---- 前面我们学习了4个函数——strlen\strcpy\strcat...文章目录 长度受限制的字符串函数 strncpy strncat strncmp 字符串查找 strstr strstr的模拟实现 strtok 错误信息报告 strerror 字符分类函数 长度受限制的字符串函数...拷贝num个字符从源字符串到目标空间。 如果源字符串的长度小于num,则拷贝完源字符串之后,在目标的后边追加0,直到num个。...(注: strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容 并且可修改。)...s\n", strerror(3)); printf("%s\n", strerror(4)); printf("%s\n", strerror(5)); } 这些并不需要我们记住,error-C语言设置的一个全局的错误码存放的变量

    3.6K20

    C语言字符串指针

    http://c.biancheng.net 除了字符数组,C语言还支持另外一种表示字符串的方法,就是直接使用一个指针指向字符串,例如: char *str = "http://c.biancheng.net..."; 或者: char *str; str = "http://c.biancheng.net"; 字符串中的所有字符在内存中是连续排列的,str 指向的是字符串的第 0 个字符;我们通常将第 0 个字符的地址称为字符串的首地址...关于全局数据区、栈区、常量区以及其他的内存分区,我们将在《C语言内存精讲》专题中详细讲解,相信你必将有所顿悟,从根本上理解C语言。...到底使用字符数组还是字符串常量 在编程过程中如果只涉及到对字符串的读取,那么字符数组和字符串常量都能够满足要求;如果有写入(修改)操作,那么只能使用字符数组,不能使用字符串常量。...最后我们来总结一下,C语言有两种表示字符串的方法,一种是字符数组,另一种是字符串常量,它们在内存中的存储位置不同,使得字符数组可以读取和修改,而字符串常量只能读取不能修改。

    6.1K20

    C语言字符串常量

    C语言字符串常量 一.字符串常量的声明 char *p = "hello";//指针直接往上戳 一个字符串常量为什么会给一个指针赋值? ...字符串常量是一个表达式,既然使表达式就会有值,字符串常量的值是该字符串第一个字母的首地址 同一个字符串常量,它们的值(地址)相同 #include ...,输出的结果却一样,这就说明多次使用同样内容的字符串常量,在内存中,都只保存一次该字符串常量。...结论:字符串本身是有值的,就是第一个字符的地址。...2.如果要修改字符串的值,我们只能使用字符数组的形式来存储字符串,可以这样声明:char str[] = "hello";,这样就可以修改了,它两本质上的不同是存储的位置不同。

    5.6K20

    C语言-字符串处理

    前言 字符串C语言里使用非常多,因为很多数据处理都是文本,也就是字符串,特别是设备交互、web网页交互返回的几乎都是文本数据。...字符串的定义 char buff[]="我是一个字符串"; char a[]="1234567890"; char b[]="abc"; char c[]={'a','b','c','\0'}; 在普通的字符数组结尾加一个...字符串删除 从键盘上录入一个字符串,删除字符串里指定的单词,输出结果。...字符串插入 从键盘上录入一个字符串,从指定位置插入一个字符串,再输出结果。 比如:原字符串“1234567890” (1). 从指定位置插入新的单词。 比如 从第2个下标插入一个“ABC”字符串。...录入数据*/ printf("录入源字符串:"); scanf("%s",str1); printf("录入要插入字符串:"); scanf("%s",str2); printf("输入要插入的下标位置

    3K30

    C语言字符串分割

    C语言中,内置的函数库中除了可以用strtok()来对字符串进行分割之外,还可以用sscannf()对字符串进行分割。...sscanf(buf, "%s %s %d", a, b, &c); printf("%s\n%s\n%d\n", a, b, c); return 0; } sscanf()的第一个参数是要分割的字符串...,第二个参数是格式化,后面的参数是分割之后的字符串的存储位置,上述程序运行之后 a = hello b = world c = 133 用sscanf()分割字符串的话,只能以空格分割字符串 sscanf...相对是字符串的格式化输入,将buf中的字符串按照sscanf的第二个参数的格式输入后面的参数中,需要说明的是程序中的c的类型也可以定义为char类型数组,第二个参数也要跟着改变,如 char a[10]...3; ++i) { printf("%s\n", buf[i]); } return 0; } 上面的程序会打印 hello world 123 用strtok分割出来的字符串都是字符串类型

    3.4K10

    C语言 | 复制字符串

    例69:C语言编写一个程序,将字符数组str2中的全部字符复制到字符数组str1中,要求不使用strcpy函数。 解析:复制时「\0」也要复制过去,「\0」后面的字符不复制 。...[80];//定义字符数组    int i;//定义整型变量    printf("输入要复制的字符串:");//提示语句    scanf("%s",str2);//输入字符串    for(i=0...    return 0;//主函数返回值为0  } 编译运行结果如下: 输入要复制的字符串:love 复制后的字符串是:love -------------------------------- Process...以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~ C语言 | 将s2中的字符复制到s1中,不用strcpy 更多案例可以go公众号:C...语言入门到精通

    3.2K64

    C语言字符串详解

    字符串是一种非常重要的数据类型,但是C语言不存在显式的字符串类型,C语言中的字符串都以字符串常量的形式出现或存储在字符数组中。...一、字符串常量和字符数组 1.1、什么是字符串常量 C 语言虽然没有字符串类型,但是 C语言提是存在字符串这个概念的,也就是字符串常量:以 NUL 字节结尾的 0 个或多个字符组成的序列。...因此,在 C 语言中是不能直接进行字符串赋值的(因为没有字符串类型嘛)。...五、字符串比较 C 语言中使用库函数 strcmp 来进行字符串比较。...6.3 查找一个 可以使用 strstr 函数来在一个字符串中查找一个: char *strstr(char const *str1 , char const *str2); 这个函数在 str1

    3.5K88

    C 语言字符串模型 ( 字符串翻转模型 )

    文章目录 一、字符串翻转模型 二、完整代码示例 一、字符串翻转模型 ---- 业务场景 : 给定下面的字符串 , 将下面的字符串翻转 ; // 将下面的字符串翻转 char str[]...= "sdfsdfsdabc4548411abc"; 计算字符串长度 : 目的是为了得到 指向 字符串 收尾位置的 指针 ; // 计算字符串长度 int len = strlen(str...); 收尾指针 : 声明两个指针 , 分别指向字符串收尾字符元素 ; // 指向字符串开始位置的指针 char *p_start = str; char *p_end = str...+ len - 1; 字符串翻转 : 从两头向中间遍历 , 收尾指针指向的元素互换 , 以达到字符串翻转的目的 ; // 从两边向中间遍历 // 利用指向收尾的指针 , 交互指针指向的元素..., 因此必须是 可修改的 栈内存 或 堆内存 , 不能是 全局区内的常量字符串 ; 参考 【错误记录】C 语言中通过指针操作字符串常量出错记录 ( 只有 栈内存 或 堆内存 中的数据才能通过指针修改

    50310
    领券