strrev 實作 (strrev Implementation)

strrev 實作 (strrev Implementation)

字串反轉 strrev 實作 教學與筆記。

說明

假設字串長度為 n,將索引值 0 和 n-1 字元調換,再換 1 和 n-2,直到字串中間為止。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#include <stdio.h>

void _swap(char *a, char *b) {
char temp = *a;
*a = *b;
*b = temp;
}

int _strlen(char *s) {
int size = 0;

while(*s) { // *s != '\0'
size++;
s++;
}

return size;
}

void _strrev(char *s) {
int front = 0;
int end = _strlen(s)-1;

for (; front < end; front++, end--) {
_swap(s + front, s + end);
}
}

void main() {
char str[] = "ABCD";
_strrev(str);
printf("%s", str); // DCBA
}
Author

Meow Lucian

Posted on

2019-07-17

Updated on

2022-07-04

Licensed under

Comments