编写函数reverse_string,原型如下:
void reverse_string(char * string)
函数把参数字符串中的字符反转反向排列,请使用指针而不是数组下标,不要使用任何C函数库中用于操作字符串的函数,不要声明局部数组来存储参数字符串。
这个题目很简单,也是面试初级程序员最基本的题目,但这个题目虽然很简单,但是需要清楚的理解指针运算才能正确做出来。
我们很容易就可以分析出步骤:
1、由于不能使用其他库函数,所以, 第一步就是用一个指针next指向字符串尾部。
2、字符串的头部指针string和倒数的next交换字符串数据,并且相向移动。
这里最终的2点:
1、next指针往后移动直到'\0',string指针和next指针的交换不包括next一开始指向的'\0',所以需要注意next指针在开始交换数据前得位置。
2、数据交换的循环条件怎么得来?
直接*string != '\0'可以吗? 当然不行,2个指针在相互靠拢的过程中数据在不断的交换,所以如果过了中线,后面的数据又会被交换回来,所以这样肯定不行&#x