当前位置: 首页 > news >正文

【C语言】左旋字符串(三种实现方式)

题目:

实现一个函数,可以左旋字符串中的k个字符。

例如:
ABCD左旋一个字符得到BCDA
ABCD左旋两个字符得到CDAB

方法一:

我们画个图分析一下:

b920d5c1c0f3467296f9cc65526cf8f0.png

基本逻辑:

就是我们每一次旋转之前,我们就取出 arr 数组的首元素存放在 tmp 中,然后将 arr 数组剩余的每一个元素都往前移动一位,最后我们再把 tmp 中的元素放回 arr 数组末尾的位置。

实现算法:

我们发现,abcd 4个字符旋转 k = 4 个字符时,数组就回到了本身数组 abcd 。这时,我们可以这样理解,虽然我们旋转了4个字符,但我们实际上我们旋转了0个字符;依次类推,旋转5个字符,实际上旋转了1个字符;接下去也是如此......接下来,我们再把字符长度加长,变成abcde 5个字符,旋转 k = 5 个字符时,数组就回到了本身数组 abcde,后面的分析就跟4个字符分析是一样的。然后,我们能够得到这样一个表达式 num(实际次数) = k % len(数组字符个数)。

代码实现:

#include <stdio.h>
#include <string.h>

void Turn_left(char arr[],int k)
{
	int len = strlen(arr);
	//求得真实的旋转次数
	int num = k % len;
	for (int i = 0; i < num; i++)
	{
		//每次移动一个
		char tmp = arr[0];
		int j = 0;
		for (j = 0; j < len - 1; j++)
		{
			//移动数据
			arr[j] = arr[j + 1];
		}
		arr[j] = tmp;
	}
}
int main()
{
	char arr[] = "abcd";
	int k = 0;
	scanf("%d", &k);//输入旋转字符个数
	Turn_left(arr, k);
	printf("%s\n", arr);

	return 0;
}

运行结果:

900747953191454fa010f03f7dda81aa.png

方法二:

我们也可以画个图分析一下:

375f845101e249ff824d9e5b959b1fdd.png

这里我们要用到两个函数:

strcpy() //字符串拷贝
strcpy(str1,str2)//将str2的元素拷贝到str2中


strncat()//这也是字符串拷贝
strncat(tmp,arr,k)//把arr开始的元素 拷贝到tmp这个字符串的后面,拷贝k个

代码实现:

#include <stdio.h>
#include <string.h>

void Turn_left(char arr[], int k)
{
	int len = strlen(arr);
	int num = k % len;
	char tmp[1000] = { 0 };
	//从arr + num的位置 开始拷贝字符串到tmp里面 
	strcpy(tmp, arr + num);

	//把arr开始的元素 拷贝到tmp这个字符串的后面,拷贝num个
	strncat(tmp, arr, num);

	//最后将tmp整个数组元素复制到arr数组中
	strcpy(arr, tmp);
}

int main()
{
	char arr[] = "abcd";
	int k = 0;
	scanf("%d", &k);//输入旋转字符个数
	Turn_left(arr, k);//2
	printf("%s\n", arr);

	return 0;
}

运行结果:

528a5e99ba6343d6ba5b5b30eb68e81c.png

方法三:

最后一种方式我们也画图分析一下:

39ae9f1a5735427b925a6bc7e96f1ba3.png

代码实现:

#include <stdio.h>

void Reverse(char arr[], int i, int j)
{
	while (i < j)
	{
		char tmp = arr[i];
		arr[i] = arr[j];
		arr[j] = tmp;
		i++;
		j--;
	}
}

void Turn_left(char arr[], int k)
{
	int len = strlen(arr);
	int num = k % len;
	//将num位置前面的元素逆序
	Reverse(arr, 0, num - 1);

	//将num位置以及之后的元素逆序
	Reverse(arr, num, len - 1);

	//整个数组逆序
	Reverse(arr, 0, len - 1);
}


int main()
{
	char arr[] = "abcd";
	int k = 0;
	scanf("%d", &k);//输入旋转字符个数
	Turn_left(arr, k);//2
	printf("%s\n", arr);

	return 0;
}

运行结果:

49633af2b86e4360b02545f7bc77190c.png

相关文章:

  • 【Git版本控制器】:第一弹——Git初识,Git安装,创建本地仓库,初始化本地仓库,配置config用户名,邮箱信息
  • fps动作系统9:动画音频
  • DeepSeek遇袭后的深思:ManageEngine ITOM如何筑牢安全防线
  • Uniapp 获取定位详解:从申请Key到实现定位功能
  • 告别同步费用!用「缤纷云 + 思源」实现 50G 免费空间 + 思源笔记加密同步,这份薅羊毛攻略藏不住了
  • 游戏引擎学习第101天
  • Redis 数据类型 String 字符串
  • java商城解决方案
  • NixHomepage - 简单的个人网站
  • C#运动控制——轴IO映射
  • Fiori APP配置中的Semantic object 小bug
  • SSE与Websocket详解,SSE实现对话框流式输出
  • react项目引入tailwindcss不生效解决方案
  • 手撕Transformer编码器:从Self-Attention到Positional Encoding的PyTorch逐行实现
  • NPDP学习笔记 -产品经理(第二版)-第三章 产品创新流程
  • 开源模型应用落地-安全合规篇-用户输入价值观判断(四)
  • 电脑显示器无信号是什么原因?查看解决方法
  • js实现点击音频实现播放功能
  • Node.js入门篇
  • C/C++后端开发面经
  • 盐城seo网站优化软件/杭州网站推广与优化
  • 网站建设的功能需求分析策划书/30条新闻摘抄
  • 企业展厅设计理念/seo专员是做什么的
  • 做网站的财务会涉及到的科目/网站推广seo是什么
  • 咖啡网站源码/中国十大营销策划机构
  • 网站用的横幅广告怎么做/内部优化