C语言的字符串倒置问题


#include <stdio.h>
int main()
{
	
	char c[] = "hello world";
	int len = 0;
	while (c[len])//此法求出的长度即为字符串的有效长度
	{
		len++;//如果到了字符串的结尾,则不再加1
	}
	printf("%d\n",len);
	
	int le = 0;
	while (c[le++]);//此法求出的长度比字符串的有效长度多1
	printf("%d\n",le);
	


	//字符串(仅含字母)倒置
	
	char c[] = "hello world";
	int len=0;
	while (c[len++]);
	len--;

	int min = 0;
	int max = len - 1;
	while (min<max)
	{
		char temp = c[min];
		c[min] = c[max];
		c[max] = temp;
		min++;
		max--;
	}
	
	printf("%s",c);
	

	//字符串倒置(汉字)
	char c[] = "你好世界";
	int len = 0;
	while (c[len++]);
	len--;
	printf("%d\n",len);//输出8,因为一个汉字占两个字节

	int min = 0;
	int max = len - 1;
	while (min < max)
	{
		char temp = c[min];
		c[min] = c[max-1];
		c[max-1] = temp;

		temp = c[min+1];
		c[min+1] = c[max];
		c[max] = temp;

		min+=2;
		max-=2;
	}
	printf("%s",c);


	getchar();
	return 0;
}
如果按照与纯字母倒置的方法对汉字的字符串进行倒置的话,结果会乱码:

因为:


修改以后则正确:

需要说明的是,如果一个字符串中既含有汉字又含有字母的话会比较复杂,但一个有用的规律是,汉字占两个字节的第一个字节用%d输出会是一个负数,而字母则不是。

例如:


图中的buf[0]即为汉字的“你”的第一个字节。

所以统计一个含有字母和汉字的字符串中字符的个数(而不是字节的个数)的方法为:

        char buf[] = "你好abc";
	int len = 0;
	int i = 0;
	while (buf[i])
	{
		if (buf[i] < 0)//说明是汉字
		{
			i += 2;//前进两个字节
		}
		else
		{
			i++;
		}
		len++;
	}

	printf("%d\n",len);
输出的即为含有的字符个数:5。

汉字在Linux系统中是以utf-8的方式进行编码的,占3个字节。

相关文章

迭代器模式(Iterator)迭代器模式(Iterator)[Cursor]意图...
高性能IO模型浅析服务器端编程经常需要构造高性能的IO模型,...
策略模式(Strategy)策略模式(Strategy)[Policy]意图:定...
访问者模式(Visitor)访问者模式(Visitor)意图:表示一个...
命令模式(Command)命令模式(Command)[Action/Transactio...
生成器模式(Builder)生成器模式(Builder)意图:将一个对...