中文字符串逆序输出

今天碰到这个题,让我逆序输出中文字符串,可给我烦死了,之前没有遇到过,也是查了资料才知道,让我太汗颜了。

英文字符串逆序输出很容易,开辟一块空间用来存放逆序后的字符串,从后往前遍历原字符串,对现在这个字符串赋值即可,代码如下:

复制代码
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int main()
{
	char s[] = "hello";
	int len = strlen(s);
	char* str = (char*)malloc(sizeof(char) * len + 1);
	int j = 0;
	for (int i = len - 1; i >= 0; i--)
	{
		str[j++] = s[i];
	}
	str[j] = '\0';
	for (int i = 0; i < len; i++)
	{
		printf("%c", str[i]);
	}
	return 0;
}

是不是很简单,那你可能就会说,中文字符串逆序输出有什么难的,把 hello改成你想逆序输出的不完了吗?我也是这样想的,结果大错特错!

接下来我查了资料才发现了我之前不知道的知识点,我们知道在字符编码方面,ASCII码为标准符号、数字、英文等进行了保留,取值范围是0~127,还有一部分作为拓展ASCII码128~255,当我们采用非ASCII编码时(汉字编码),一般用拓展ASCII码来进行,约定用128~255范围的连续2个进行汉字编码,同时因为编码的问题汉字所占字节的第一位必须是1,这样转化成有符号数字之后是小于0的,转化成无符号数字就大于127,这就涉及到了编码的知识,有兴趣的自行了解,因此,在处理字符串时,如果是有符号字符串,遇到小于0的字符,会结合后面紧跟的字符来组成一个汉字,如果是无符号的,则判断是否大于127

还有就是一个汉字占用两个字节,知道了以上的知识,才能写出正确的代码。

复制代码
#include<stdio.h>
#include<string.h>
int main()
{
	char s[] = "你好张三";
	int len = strlen(s);
	char* p = s;
	for (int i = len - 1; i >= 0;)
	{
		if (p[i] < 0)//判断字符值是否小于0,这里默认char是signed char类型
		{
			for (int k = i - 1; k <= i; k++)
			{
				printf("%c", p[k]);//字符值小于0,则说明它和它前面一个表示一个汉字
			}
			i -= 2;//遍历跳过两个字节,一个汉字占两个字节
		}
	}
	return 0;
}
相关推荐
qq_339554828 小时前
英飞凌ModusToolbox环境搭建
c语言·eclipse
张張4088 小时前
(域格)环境搭建和编译
c语言·开发语言·python·ai
༾冬瓜大侠༿9 小时前
vector
c语言·开发语言·数据结构·c++·算法
独小乐9 小时前
009.中断实践之实现按键测试|千篇笔记实现嵌入式全栈/裸机篇
linux·c语言·驱动开发·笔记·嵌入式硬件·arm
Proxy_ZZ09 小时前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法
ambition2024210 小时前
斐波那契取模问题的深入分析:为什么提前取模是关键的
c语言·数据结构·c++·算法·图论
艾莉丝努力练剑10 小时前
C++ 核心编程练习:从基础语法到递归、重载与宏定义
linux·运维·服务器·c语言·c++·学习
Ghost Face...10 小时前
Linux USB 全栈解析:OTG + Type-C + PD 内核架构(架构师级)
linux·c语言·架构
蓝牙先生11 小时前
22_backlightLinux内核模块
linux·c语言
ambition2024211 小时前
【算法详解】飞机降落问题:DFS剪枝解决调度问题
c语言·数据结构·c++·算法·深度优先·图搜索算法