十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
1、新建一个工程和.c文件,输入头文件和主函数。
我们提供的服务有:做网站、成都网站设计、微信公众号开发、网站优化、网站认证、麟游ssl等。为上千家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的麟游网站制作公司
2、定义变量类型。
3、调用cpy函数。
4、定义一个函数,并定义变量类型。
5、用一个For 语句和if语句判断是否为元音。
6、最后加一个字符串结束符,并在主函数中输出。
7、编译。运行。
strcat(p1+2,p2+1)
p1+2,也就是p1向后移动两个字符位置的指针作为一个字符串的起始指针,即字符串为"cd"
p2+1,也就是p2向后移动一个字符位置的指针作为一个字符串的起始指针,即字符串为"BCD"
该函数调用将p1+2作为目的串,p2+1作为源串,将后者连接到前者的后面,则连接后为"cdBCD"。
strcpy(str+2, .....)
该函数调用将 后面的串"cdBCD"复制到前者str+2,即"z"的位置,这是一种覆盖复制。则'z'被'c'覆盖(原来前面的"xy"保留了下来),后面接着放了"cBCD";
最后输出的是str,也就是从str的最开始输出,故结果为"xycdBCD"
#includestdio.h
void s_trcat(char *s1,char *s2);//连接两个字符串
void s_trcpy(char *s1,char *s2);//字符串s2复制给字符串s1
int s_trcmp(char *s1,char *s2);//两个字符串比较大小
int s_trlen(char *s);//计算一个字符串的长度
int main()
{
char s1[11]="12345", s2[11]="ABCDE";
char x1[11]="12345",x2[11]="SSSKK";
char str1[11]="ABCD",str2[11]="ACB";
char s[11]="ABCDEF";
int n,len;
s_trcat(s1,s2);//拼接s1,s2
printf("拼接s1,s2,输出s1\n");
puts(s1);
s_trcpy(x1,x2);//将x2的内容复制给x1
printf("将x2的内容复制给x1,输出x1\n");
puts(x1);
n=s_trcmp(str1,str2);//比较str1与str2大小,返回一个整数,代表比较的结果
if(n==0)
printf("str1与str2相同\n");
if(n==1)
printf("str1大于str2\n");
if(n==-1)
printf("str1小于str2\n");
len=s_trlen(s);//计算字符串s的长度,并返回一个整数(字符串长度),
printf("字符串s的长度:%d\n",len);
}
void s_trcat(char *s1,char *s2)//连接两个字符串
{
char *p=s1;
char *q=s2;
while(*p)
p++;
while(*q)
{
*p=*q;
p++;
q++;
}
*p='\0';//给新字符串尾部加个结束符
}
void s_trcpy(char *s1,char *s2)//字符串s2复制给字符串s1
{
char *p=s1;
char *q=s2;
while(*p++=*q++);
*p='\0';//给新字符串尾部加个结束符
}
int s_trcmp(char *s1,char *s2)//两个字符串比较大小
{
char *p=s1;
char *q=s2;
int len1=0,len2=0;
while(*p++)
len1++;
while(*q++)
len2++;
p=s1,q=s2;
while(*p!='\0'*q!='\0')
{
if(*p*q)
return 1;
if(*p*q)
return -1;
p++;
q++;
}
if(len1==len2)
return 0;//返回0,两个字符串相同
if(len1len2)
return 1;//返回1,前大于后
if(len1len2)
return -1;//返回-1,前小于后
}
int s_trlen(char *s)//计算一个字符串的长度
{
char *p=s;
int len=0;
while(*p++)
len++;
return len;//返回字符串长度
}
对于strcat,其格式为
char *strcat(char *a, char *b);
其功能为,将字符串b拼接到a的尾部,并将结果字符串返回。
所以,实现该函数的思路为:
1 找到字符串a的结尾;
2 将b的所有字符复制到a尾部的空间中,到\0为止。
需要注意的是,复制的结果要包含b的结束符。
代码如下:
char *strcat(char *a, char *b)
{
char *p = a;
while(*p) p ++;
//当*p为\0时退出,即查找到a的结尾。
do
{
*p++ = *b;//将b中的每个字符复制到p中。
if(*b == '\0')break;//遇到结束符退出。
b++;//移动指针b的位置。
}while(1);
return a;//返回结果字符串首地址。
}