nullで終了する文字列(nullで終了するchar文字列、それは冗長ですか?)の逆関数を実装したかったのでchar*
、次の解決策を思いつきました。
逆関数の最後のスワップswap(&tmp, &str)
は効果がありません。理由は何ですか、おそらくそれはどのように行われますか?
備考:文字列自体、一時文字、インデックスのみを使用して逆関数をすでに再実装しましたが、なぜこれが機能しないのか非常に興味があります。このポインタの問題で私は何を考慮していませんか?
#include <stdlib.h>
#include <stdio.h>
int strlen(char* str)
{
int len = 0;
char* ptr = str;
while (ptr[0] != '\0')
{
len++;
ptr++;
}
return len;
}
void swap(char **a, char **b)
{
char* c = *a;
*a = *b;
*b = c;
}
void reverse(char* str)
{
int len = strlen(str);
char* tmp = malloc(sizeof(char) * (len + 1));
int i;
for (i = 0; i < len; i++)
{
tmp[i] = str[len - 1 - i];
}
tmp[len] = '\0';
// printf(tmp); => "wolfrevOkcatS olleH"
swap(&tmp, &str);
}
int main(int argc, char** argv)
{
char* str = "Hello Stackoverflow\0";
reverse(str);
printf("%s", str);
return 0;
}