C语言--关于字符串逆序那些事

1.整个字符串逆序

要想实现字符串的逆序就要想办法将字符进行调换,可以通过控制下标来调换字符,类似于之前的泡沫排序法,都是设出了左右坐标:

//版本一,用数组做形参
//void Reverse(char ch[], int len)
//{
//	int left = 0;
//	int right = len - 1;
//	int i = 0;
//	while (left < right)
//	{
//		char temp = ch[right];
//		ch[right] = ch[left];
//		ch[left] = temp;
//		left++;
//		right--;
//	}

}
//版本二:用指针做形参
void Reverse(char* ch, int len)
{
	char* left = ch;
	char* right = ch + len - 1;
	while (left < right)
	{
		char temp = *left;
		*left = *right;
		*right = temp;
		right--;
		left++;
	}
}


int main()
{
	char ch[] = "abcdefghi";
	int len = strlen(ch);
	Reverse(ch,len);
	printf("%s", ch);
	return 0;
}

2.单词本身不逆序,只将单词的排列顺序逆序:

可以先考虑将单个的单词字母逆序,然后将整个字符串逆序:

 

 

int main()
{
	char ch[] = "abcd efgh ijhk.";
	char* left = ch;
	char* right = ch + strlen(ch) - 1;
	//逆序单个单词
	char* start = ch;
	char* end = start;
	while (*end != '\0')
	{
		while (*end != ' ' && *end != '\0')
		{
			end = end + 1;
		}
		char* ret = end - 1;
		while (ret > start)
		{
			int temp = *start;
			*start = *ret;
			*ret = temp;
			ret--;
			start++;
		}
		if (*end == '\0')
			start = end;
		else
			start = end + 1;
		end = start;
	}
	//逆序整个字符串
	while (left < right)
	{
		char temp = *left;
		*left = *right;
		*right = temp;
		right--;
		left++;
	}
	printf("%s\n", ch);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_w_z_j_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值