逆转字符串内容(C语言)

问题描述:

有一个字符数组的内容为:“student a am i”,
请你将数组的内容改为"i am a student".
要求:
不能使用库函数。
只能开辟有限个空间(空间个数和字符串的长度无关)。

student a am i
i ma a tneduts
i am a student

思路:

对字符串内容进行逆转,可以先逆转整个句子的顺序,再逆转每个单词的顺序。

用到的函数及作用:

void Reverse_one(char *left, char *right)
{
	
	while (left < right){
		char t = *left;
		*left = *right;
		*right = t;
		left++;
		right--;
	}
}

这一部分函数,对指定长度的字符串进行逆转(长度为right-left),当left < right成立时,交换left和right指向的内容

void Reverse(char *p, int len)
{
	char *left = p;
	char *right = p + len - 1;
	Reverse_one(left, right);
	while(*p){
	//找到每个单词
		left = p;
		while ((*p != ' ') && (*p != '\0')){
			p++;
		}
		right = p - 1;
		//对每个单词进行逆转
		Reverse_one(left, right);
		if (*p == ' '){
			p++;
		}
	}
}

在这一部分函数中,首先,将整个字符串逆转,结果是:
在这里插入图片描述
然后,在对每一个单词进行逆转,结果是:
在这里插入图片描述
即可完成题目要求

用到的知识点:

1、数组传参会发生降维,降维成指向数组内容的指针;
2、对指针解引用表示的是指针所指向的目标;
3、指针加一,加的是其所指向类型的大小;

运行结果:
在这里插入图片描述

完整代码:

#include<stdio.h>
#include<windows.h>
void Reverse_one(char *left, char *right)
{
	
	while (left < right){
		char t = *left;
		*left = *right;
		*right = t;
		left++;
		right--;
	}
}
void Reverse(char *p, int len)
{
	char *left = p;
	char *right = p + len - 1;
	Reverse_one(left, right);
	while(*p){
		left = p;
		while ((*p != ' ') && (*p != '\0')){
			p++;
		}
		right = p - 1;
		Reverse_one(left, right);
		if (*p == ' '){
			p++;
		}
	}
}
void main()
{
	char str[] = "student a am i";
	int len = sizeof(str) / sizeof(str[0])-1;
	printf("原字符串为 > %s\n", str);
	Reverse(str, len);
	printf("逆置后的字符串为 > %s\n", str);
	system("pause");
}
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值