首页 > 其他 > 详细

字符串反转

时间:2016-03-26 08:56:55      阅读:248      评论:0      收藏:0      [点我收藏+]
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>

void reverse_str(char *left, char *right)
{
	assert(left);
	assert(right);
	while (left < right)
	{
		char tmp = *left;
		*left = *right;
		*right = tmp;
		left++;
		right--;
	}
}

int my_strlen(const char * str)
{
	int count = 0;
	while (*str++)
	{
		count++;
	}
	return count;
}

void reverse(char arr[])//(cahr *str)
{
	char *pstart = arr;
	char *pend = arr + my_strlen(arr)-1;
	char *pcur = NULL;
	if ((arr == NULL) || (arr[0] == ‘\0‘))
	{
		return;
	}
	reverse_str(pstart, pend);//逆序整个字符数组

	while (*arr)
	{
		pcur = arr;
		while (*arr != ‘\0‘ && *arr != ‘ ‘)
		{
			arr++;
		}
		pend = arr - 1;
		reverse_str(pcur, pend);
		if (*arr == ‘ ‘)
			arr++;
	}
}

int main()
{
	char arr[] = "student a am i";
	//i ma a tneduts
	//i am a student
	reverse(arr);
	printf("%s\n", arr);
	system("pause");
	return 0;
}


本文出自 “11275984” 博客,请务必保留此出处http://11285984.blog.51cto.com/11275984/1754971

字符串反转

原文:http://11285984.blog.51cto.com/11275984/1754971

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!