今天我想分享的是有关字符串的一写内容,我们就先从最简单的开始吧。main函数中定义一个字符串变量,我们想知道字符串的长度。字符串的长度通常是指字符串中包含字符的数目,我们可以通过调用库函数得到,我们也可以通过自己编写一个代码来实现它。
首先我们先在main函数里面定义一个字符串数组,char *Qwe="abcdef";然后定义两个指针p,q同时指向字符串的首地址,p指针不动一直指向首地址,当q指针的内容!="\0"时,它的地址一直加加,当它的内容="\0"时,用q指针指向的地址减去p指针指向的地址,得到的就是该字符串的长度。
#include<stdio.h> #include <string.h> int my_strlen(char *Xsw) { char *q=Xsw; char *p=Xsw; while (*q!='\0') { q
} return (q-p); } int main() { char *Xsw="zxcvbnm"; int ret=my_strlen(Xsw); printf("%d",ret); return 0; }
通过上面的分享想必我们已经知道如何自己编写一个代码输出字符串的长度了。接下来我想分享的是如何将一个字符串反转输出。
首先我们的先定义一个字符串数组,char arr[]="abcdef";然后定义两个指针char* left,char* right,left指针指向字符串的首地址,right指针指向字符串的最后一个字符的地址,断言一下left指针和right指针是否存在,如果存在,当left指针指向的地址小于等于right指针指向的地址时,我们新定义一个变量char tmp,用类似交换数的方法,先将left指针所指向的内容放入tmp中,再将right指针指向的内容放入left中,最后将tmp中存入left指针指向的内容放入right中,left指针的地址加加,right指针的地址减减。这样我们就实现了字符串的反转。
#include <stdio.h> #include <string.h> #include <assert.h> void reserve(char *left,char *right) { assert(left); assert(right); while (left<=right) { char tmp=*left; *left=*right; *right=tmp; left++; right--; } } void Left_move(char *arr, int n,int len) { reserve(arr,arr+n-1); reserve(arr+n,arr+len-1); reserve(arr,arr+len-1); } int main() { char arr[]="abcdef"; int len = strlen(arr); Left_move(arr,3,len); puts(arr); return 0; }