#include <stdio.h>
#include <stdlib.h>
/**
实现字符数组
将字符串颠倒,12345678--87654321
1、先用数组的方式
先求出长度
如果是基数怎么颠倒
如果是偶数怎么颠倒
2、用指针的方式
*/
int main()
{
char hj[100] ="1234567890";
int length =0; //检查字符串的长度
for (int i=0;i <100;i++) //监测有效长度
{
if (hj[i] =='\0') //遇到终止符退出
{
break;
}
else
{
length++; //计数器自增
}
}
printf("数组的长度:%d",length);
for (int i=0; i<length/2;i++) //中间数作为交换
{
char tmp = hj[i];
hj[i] = hj[length-1-i];
hj[length-1-i] = tmp;
}
printf("\n交换后的数组:after:%s",hj);
getchar();
return 0;
}
上述方法是用数组的方式实现
下是用指针的方式实现:
int main()
{
char hj[100] = "1234567890";
int length = 0; //长度
for (char *p=hj;*p!='\0';p++)
{
length = length+1;
}
printf("\n%d,%c",length);
printf("\n%c",'0','0');
printf("%d,%c",'\0','\0');
for (char *p=hj;p<hj+(length/2);p++)
{
//完成2个变量之间的交换 //*(hj+i) = *(hj+length-1-i)
// p= hj+i -->i =p-hj // hj+length-1-p+hj
int tmp = *p;
*p =*(hj+(hj+length-1-p));
*(hj+(hj+length-1-p)) = tmp;
}
printf("\n%s",hj);
getchar();
return 0;
}
版权声明:本文为zhanglin200508原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。