这是我的问题:
编写一个反转字符串的函数 void reverse(char s[])。例如,“Harry”变成“yrraH”。
这是我的代码:
void reverse(char s[]);
int main()
{
char s [] = "Harry";
reverse(s);
cout << s << endl;
system("PAUSE");
return 0;
}
void reverse(char s[])
{
int length = strlen(s);
int c, i ,j;
for(int i=0, j=length-1 ; i<j ; i++, j--)
{
c = s[i];
s[i] = s[j];
s[j] = c;
}
}
它可以完美地反转字符串。但是,我被要求用指针来做。所以从我的想法来看,首先我分配 ap 指针来获取字符串中的第一个字符。然后我分配 aq 指针以获取字符串的最后一个字符。I 循环以反转数组。但是当我试图这样做以获得最后一个字符时:
char *q = strlen(s-1);
我有一个错误。有人可以帮我用指针解决这个问题吗?
更新部分
if (strlen(s) > 0(
{
char* first = &s[0];
char*last = &s[strlen(s)-1];
while(first < last)
{
char temp = *first;
*first = *last;
*last = temp;
++first;
--last;
}
}