C语言大一新生,求解答
C语言大一新生,求解答
题目:字符串反转

函数reverse()首先遍历字符串每个字符, 以计算字符串长度,然后根据这个长度来循环将字符串前后两部分对应的字符交换位置,循环结束即将字符串完成了逆序。
测试如下:
#include <stdio.h>
void reverse(char *s){
int len=0;
char *p=s; // 让字符指针p指向字符串的起始位置
while(*p!=0){ // 遍历字符串s中的每个字符,直到遇到字符串结尾的空字符结束才结束循环
len++; // 每遍历到一个字符,字符串长度+1
p++; // 字符指针p指向字符串的下一个字符位置
}
//printf("len=%d\n",len);
int i=0; // 下标变量i,初始化为0,用于访问字符串的字符
char c;
// 如果下标变量i小于等于len/2-1,下标0到(len/2-1)为字符串前半部分字符的下标区间,(len/2)到(len-1)为字符串后半部分字符的下标区间
// 例如,字符串长度为14,则len/2-1为6, 前半部分字符下标为:0 1 2 3 4 5 6,后半部分字符下标为: 7 8 9 10 11 12 13
// 字符长度如果为奇数,例如为7,则len/2-1为2,前半部分字符下标为:0 1 2 ,后半部分字符下标为:4 5 6 ,下标为3的字符位于字符串正中间不用交换
while(i<=len/2-1){
printf("i=%d,len-1-i=%d\n",i,len-1-i);
c=*(s+i); // 将前半部分相应为的字符赋值给字符变量c
*(s+i)=*(s+len-1-i); // 将前半部分的相应字符修改为后半部分的相应位置的字符
*(s+len-1-i)=c; // 将后半部分相应位置的字符修改为前半部分相应位置的原字符,如此即将前后部分的字符完成交换,循环结束,字符串即完成逆序操作
i++; // 下标变量i指向下个字符位置
}
}
int main(void){
char s[] = "www.runoob.com";
// char s[] = "abcdefg";
printf("'%s' ==>\n",s); // 打印逆序前的字符串
reverse(s); // 调用函数完成字符串逆序
printf("'%s'\n",s); // 打印逆序后的字符串
return 0;
}
