C语言编程C++旋转字符操作串示例详解

 更新时间:2021年09月28日 10:12:20   作者:小码农UU  
这篇文章主要为大家介绍了C语言编程中C++旋转字符操作串示例详解,文中附含详细图文示例代码,有需要的朋友可以借鉴参考下,希望能够有所帮助

旋转字符串

字符串左旋

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

例如:

ABCD左旋一个字符得到BCDA

ABCD左旋两个字符得到CDAB

题前认知:

一个字符串如果就定死了。eg:char arr[]=“dfdf”什么的那多没意思,一点都没有人机交互的感觉,(虽然现在人机交互适合个体,不适合集群,但也是比死板的定死字符串舒服)

所以字符串得是我们可输入的,才有可玩性,玩的不尽性就循环

暴力移位:

#include<stdio.h>
#include<string.h>
char* turn_left(char* arr, int num)
{
	int len = strlen(arr);
	int i = 0;
	//左旋数是多少就进行几次移位
	for (i = 0; i < num; i++)
	{
		//每次移位就是单次左旋
		int j = 0;
		char tmp = arr[0];//每次都把首元素存起来
		for (j = 0; j < len-1; j++)
		{			
			arr[j] = arr[j + 1];			
		}
		arr[len-1] = tmp;//把存起来的首元素放到最后一位
	}
	return arr;
}
int main()
{
	char arr[100] = {0};
	int num = 0;
	while (1)
	{
		printf("请输入想要旋转的字符串:>");
		gets(arr);
		printf("请输入想要左旋数:>");
		scanf("%d", &num);
		getchar();//这个的作用是清空缓冲区,因为每次scanf会有一个\n,不清空的话
		//下一次到了gets,他会认为\n是我们打进去的,所以scanf之后必须清空缓冲区
		printf("左旋字符串为:%s\n", turn_left(arr, num));
	}
	return 0;
}

输出结果

image-20210909232922661

三步翻转:

#include<stdio.h>
#include<string.h>
#include<assert.h>
void reverse(char* head, char* tail) //字符串逆序
{
	assert(head && tail);//断言阻止空指针
	char tmp = 0;
	char* ptmp = &tmp;
	while (head<tail)
	{
		tmp = *head;
		*head = *tail;
		*tail = tmp;
		head++;
		tail--;
	}
	return 0;
}
char* turn_left(char* arr, int num)
{
	assert(arr);
	int len = strlen(arr);
	if (len)
	{
		int n = num % len;           //防止num会越界操作,所以必须是num模len才可,还要保证len不为0
		reverse(arr, &arr[n - 1]);          //逆序左边
		reverse(&arr[n], &arr[len - 1]);  //逆序右边
		reverse(arr, &arr[len - 1]);      //逆序整体
		return arr;
	}
	else
	{
		return arr;
	}
}
int main()
{
	char arr[100] = {0};
	int num = 0;
	while (1)
	{
		printf("请输入想要旋转的字符串:>");
		gets(arr);
		printf("请输入想要左旋数:>");
		scanf("%d", &num);
		getchar();//这个的作用是清空缓冲区,因为每次scanf会有一个\n,不清空的话
		//下一次到了gets,他会认为\n是我们打进去的,所以scanf之后必须清空缓冲区
		printf("左旋字符串为:%s\n", turn_left(arr, num));
	}
	return 0;
}

image-20210910003317406

image-20210910100918779

还有3种方法但那三种就需要很强的数学功底了,具体的我也看不懂他怎么证明的数学公式,就不看了。哈哈哈

判断字符串旋转

写一个函数,判断一个字符串是否为另外一个字符串旋转之后的字符串。

例如:给定s1 =AABCD和s2 = BCDAA,返回1

给定s1=abcd和s2=ACBD,返回0.

AABCD左旋一个字符得到ABCDA

AABCD左旋两个字符得到BCDAA

AABCD右旋一个字符得到DAABC

题前认知

大家现在应该知道我干啥,没错我倡导交互,两个字符串都是我们写

字符串追加判断

(面试的时候能用库函数就用库函数)

什么叫字符串追加判断呢 例如asdfg这个字符串

image-20210913231753342

#include<stdio.h>
#include<string.h>
#include<assert.h>
int is_left_move(char* str1, char* str2)
{	
	assert(str1 && str2);
	int len1 = strlen(str1);
	int len2 = strlen(str2);
	//长度不同就肯定不是旋转字符串
	if (len1 - len2)
		return 0;
	//在arr1字符串中追加一个自己
	strncat(str1, str1, len1);
	//判断判断的那个字符串是不是追加字符串的子串
	char* ret = strstr(str1, str2);
	if (ret == NULL)
		return 0;
	else
		return 1;
}
int main()
{
	char arr1[50] = {0};//有足够的空间
	char arr2[50] = {0};
	while (1)
	{
		printf("请输入字符串:>");
		gets(arr1);
		printf("请输入需判断的旋转字符串:>");
		gets(arr2);
		int ret = is_left_move(arr1, arr2);
		if (ret == 1)
		{
			printf("是旋转字符串\n");
		}
		else
		{
			printf("不是旋转字符串\n");
		}
	}	
	return 0;
}

结果

image-20210913231922969

以上就是C语言编程C++旋转字符操作串示例详解的详细内容,更多关于C语言编程C++旋转字符串的资料请关注脚本之家其它相关文章!

相关文章

  • C++ Qt开发之PushButton按钮组件的使用详解

    C++ Qt开发之PushButton按钮组件的使用详解

    Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,本文将重点介绍QPushButton按钮组件的常用方法及灵活运用,感兴趣的小伙伴可以学习一下
    2023-12-12
  • C++实现LeetCode(33.在旋转有序数组中搜索)

    C++实现LeetCode(33.在旋转有序数组中搜索)

    这篇文章主要介绍了C++实现LeetCode(33.在旋转有序数组中搜索),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C语言中strlen()函数的使用详解

    C语言中strlen()函数的使用详解

    strlen函数是用来求字符串长度的函数,这个函数遇到‘\0’就会停止,且这个长度不包含‘\0’,这篇文章给大家介绍了C语言中strlen()函数的使用,感兴趣的朋友一起看看吧
    2024-02-02
  • Qt编写地图之实现经纬度坐标纠偏

    Qt编写地图之实现经纬度坐标纠偏

    地图应用中都涉及到一个问题就是坐标纠偏的问题,这个问题的是因为根据地方规则保密性要求不允许地图厂商使用标准的GPS坐标,而是要用国家定义的偏移标准。本文将详细讲解如何在Qt中实现经纬度坐标纠偏,需要的可以参考一下
    2022-03-03
  • OpenCV实现更改图片颜色功能

    OpenCV实现更改图片颜色功能

    这篇文章主要为大家详细介绍了如何利用OpenCV实现更改图片颜色的功能,文中代码介绍详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • C++实现list增删查改模拟的示例代码

    C++实现list增删查改模拟的示例代码

    本文主要介绍了C++实现list增删查改模拟,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • 基于C++实现的各种内部排序算法汇总

    基于C++实现的各种内部排序算法汇总

    这篇文章主要介绍了基于C++实现的各种内部排序算法,非常经典,需要的朋友可以参考下
    2014-08-08
  • c++如何实现归并两个有序链表

    c++如何实现归并两个有序链表

    这篇文章主要介绍了c++如何实现归并两个有序链表,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • 解析Linux下的时间函数:设置以及获取时间的方法

    解析Linux下的时间函数:设置以及获取时间的方法

    本篇文章是对Linux下的时间函数:设置以及获取时间的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C语言实现猜数字小项目

    C语言实现猜数字小项目

    这篇文章主要为大家详细介绍了C语实现猜数字小项目,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01

最新评论