逆转汉字
方法:一个汉字占两个字节,将两个字节看成一个整体,定义两个数组用于存储,将源字符数组的汉字从头开始放到临时数组的结尾到开头,最后将临时数组(已经逆转)在赋给原数组
#include <iostream>
#include <string>
#include <stdio.h>
using namespace std;
void reverse(unsigned char* s) {
unsigned char tmp[1024] = {0};
int len = strlen((char*)s);
unsigned char* p1 = s;
unsigned char* p2 = tmp + len;
*p2-- = 0;
while (*p1)
{
if (*p1 < 0x80) {
*p2-- = *p1++;
}
else {
*(p2 - 1) = *p1++;
*p2 = *p1++;
p2 -= 2;
}
}
for (int i = 0; i < len; i++)
{
s[i] = tmp[i];
}
}
int main(void) {
unsigned char str[] = "我是小萌新";
reverse(str);
printf("%s\n", str);
return 0;
}