上一篇博客,我们实现了利用多次左旋,把要比较的字符串的各种旋转情况 与原字符串 一一比较,从而找出其中是否有一个相吻合来实现判断
我这一次学到了strcat 与strstr函数实现该判断的方法
老样子 先看主函数
其中,a用来接收返回值,根据返回值打印相关判断。
划重点!!!!
arr1是这一次我们要追加的函数,他的方括号里有个30,小细节哦,后面来说说为什么。
我们先来介绍一下strcat 与strstr函数
strcat:
简单地理解,strcat(arr1,arr2)就是在arr1后面追加一个arr2,而arr1字符串后面的\0会被覆盖
如果我要实现一个字符串追加自己,要在str和cat之间加一个n,因为\n会被覆盖,第二次读取arr函数时没有\0,会一直读取下去,因此我们要使用srtncat函数
区别:strncat(arr1,arr1,len)要加一个要追加的函数的长度,如图
这样,arr1从abcdef\0变成了abcdefabcdef\0可以明显看出,追加后的函数含有任何旋转情况的abcdef字符串
这水印好讨厌啊)
strstr:
strstr(arr1,arr2)意思是在arr1里面找有没有与arr2匹配的字符串.
如果没有,返回空指针,如果有,返回相应的地址.
比如找到了cdefgab,返回c的地址.
使用char*接收字符的地址,非常合理
注:NULL是空指针
最后谈谈为什么要在主函数里的arr1的方括号里加一个30呢?
因为追加后arr1的大小会改变,为了防止访问冲突加一个足够大的数字来申请足够大的内存就好了.
啥是访问冲突?我的理解是超出内存了,不是很深刻
如果有什么优化,建议,指正,随时欢迎哦☺️