문자열을 뒤집는 또 다른 표준 접근법은 각 반복마다 두 문자를 교체하는 문자열의 시작과 끝 모두에서 작동하는 포인터를 사용합니다. 그것은 당신이 말할 수있는 여러 가지 방법이 있습니다 자리에 원래 문자열 (원본을 보존, 또는 두 번째 문자열을 전달하고 거기에 반전 된 문자열을 배치해야하는 경우 사본을)
/** strrevstr - reverse string, swaps 2 chars per-iteration.
* Takes valid string and reverses, original is not preserved.
* If 's' is valid and non-empty, returns pointer to 's',
* returns NULL otherwise.
*/
char *strrevstr (char *s)
{
if (!s || !*s) { /* validate string is not NULL and non-empty */
printf ("strrevstr() error: invalid string\n");
return NULL;
}
char *begin = s; /* pointers to beginning and end, and tmp char */
char *end = begin + strlen (s) - 1;
char tmp;
while (end > begin) /* swap both beginning and end each iteration */
{
tmp = *end;
*end-- = *begin;
*begin++ = tmp;
}
return s;
}
을 바꿉니다 이 문제와 다른 답변을 제공함으로써 문제에 접근하기 위해서는 요구 사항을 충족시키는 솔루션을 맞춤식으로 조정할 수 있어야합니다.
모든 접근 방식에는 장단점이 있습니다. 역순으로 된 문자열을 저장하기 위해 새로운 메모리 블록을 동적으로 할당하는 것은 아무런 문제가 없습니다. (1) 새로운 블록의 시작 주소에 대한 포인터를 유지하므로 (2) 더 이상 사용하지 않을 때 해제 될 수 있습니다 필요합니다. 원래 문자열을 보존해야하는 경우, 역순으로 처리 된 문자열을 보유하기에 충분한 크기의 문자 배열에 포인터를 전달하면 다른 옵션으로 원본을 보존 할 수 있습니다.
질문이 있으면 모든 대답을 살펴보고 알려주세요.
작동하지 않는 기능에 대해 좀 더 구체적으로 설명하십시오. 그것은 segfaulting인가? 컴파일에 실패 했습니까? 잘못된 결과를 주는가? – merlin2011
그리고 일관된 스타일을 가지고 있으며 읽을 수있는 코드를 작성하십시오. 또한'main()'의 성공 값은 '0'입니다. 아니면 정확하게 'EXIT_SUCCESS'. 마지막으로, 문자열을 뒤집 으면 생각해야합니다! 얼마나 많은 문자를 교환해야합니까? 그러면 왜 작동하지 않는지 알게 될 것입니다. –
로컬 배열의 주소를 반환하지만 배열에 스택이 할당되고 함수가 반환 될 때 더 이상 사용할 수 없습니다. (1)'malloc'을 호출하여 힙에 배열을'inverse' 할당합니다. (2) 호출자가 원하는 결과 배열을 가리키는 포인터를 전달하도록합니다. 또는 (3)'inverse '인수 문자열을 그 자리에서 역순으로. –