【C++】用C或C++实现void reverse(char* str)函数,即反转一个null结尾的字符串

<span style="font-family: Arial, Helvetica, sans-serif;">//reverse a string *str</span>
<span style="font-family: Arial, Helvetica, sans-serif;"></span><pre name="code" class="cpp">//null字符不用反转,所以end指向字符串倒数第二个字符即可
//注意i++ 和++i的区别
//如果用递归处理这个问题呢?


void reverse (char* str)
{
	char* end = str;
	char temp;
	
	if(str)
	{
		while(*end)
		{
			++end;
		}
		--end; //the last char is null, so we decrease one step of end
		
		while(str < end)
		{
			temp = *str;
			*str++ = *end;
			*end-- = temp; //swap value, then increase *str, decrease *end
		}
	}
}
阅读更多
个人分类: C++
上一篇【Java,面试】实现一个算法,确定一个字符串的所有字符是否全都不同
下一篇【Java】Java Arrays类进行数组排序
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭