字符串旋转结果

文章目录

    • 题目
    • 解法1
    • 解法2


题目

字符串旋转结果

写一个函数,判断一个字符串是否为另外一个字符串旋转之后的字符串。 例如:给定s1 =AABCD和s2 = BCDAA,返回1
给定s1=abcd和s2=ACBD,返回0. AABCD左旋一个字符得到ABCDA AABCD左旋两个字符得到BCDAA
AABCD右旋一个字符得到DAABC

解法1

1.我们再创建两个函数,分别用于左旋和右旋。
2.然后再每旋转一次就和另一个数组比较,当比较完n次后再转一次再比较,这时我们设置一个标志变量来判断最终这两个数组的元素是否都先相等,要是相等直接返回 1 ,要是走完了旋转都没有相等的就返回 0

代码:

void zuoxuan(char * s, int n) {//左旋函数
	char te = *s;//将首元素先给   te 
	for (int i = 0; i < n - 1; i++)//数组整体向左移动
		*(s + i) = *(s + i + 1);
	*(s + n - 1) = te;//移动动完之后再将te放到数组的最后个位置>>这样就完成了一次左移
}
void youxuan(char* s, int n) {//右旋函数
	char te = *(s + n - 1);//将最后一个元素先给   te 
	for (int i = n - 1; i > 0; i--) {//数组整体先右移动
		*(s + i) = *(s + i-1);
	}
	*s = te;//移动完再将te放到数组的第一个位置>>完成右移
}
int zhu(char* s, char* s1, int n) {
	for (int i = 0; i < n-1; i++) {//先进行n-1次的左旋,(使数组从头到尾转一次)
		int t = 0;//标志变量,当t=n是就是两个数组相等
		zuoxuan(s1, n);//调用左旋函数
		for (int j = 0; j < n; j++) {//对两个数组遍历对比
			if (*(s + j) == *(s1 + j))
				t++;
		}
		if (t == n)//判断这次旋转后是否相等,相等返回1
			return 1;
	}
	for (int i = 0; i < n-1; i++) {// 先进行n - 1次的右旋,(使数组从头到尾转一次)
		int t = 0;//标志变量,当t=n是就是两个数组相等
		youxuan(s1, n);//调用右旋函数
		for (int j = 0; j < n; j++) {//对两个数组遍历对比
			if (*(s + j) == *(s1 + j))
				t++;
		}
		if (t == n)//判断这次旋转后是否相等,相等返回1
			return 1;
	}
	return 0;//要是都不相等就返回0
}
int main() {
	char arr[] = "abcd";
	char arr1[] = "ACBD";
	int n = strlen(arr);//求数组长度
	int i = zhu(arr, arr1, n);//调用
	printf("%d\n", i);//打印
	return 0;
}

这种解法非常暴力,时间复杂度为O(n*n),空间复杂度O(1)

解法2

这种解法相对简洁

其实ABCDE无论怎么旋,旋转后的所有结果,都包含在了ABCDEABCD这个字符串里了。
所以做法很简单,只需要将原字符串再来一遍接在后面,然后找一找待查找的字符串是不是两倍原字符串的子集即可。

在写代码之前先介绍一下三个库函数
1.strcpy
在这里插入图片描述
例:

int main() {
	char arr[128] = "qwe";
	char arr1[128];
	strcpy(arr1, arr);
	printf("%s", arr1);
	return 0;
}

运行结果:
在这里插入图片描述
2.strcar
在这里插入图片描述
例:

int main() {
	char arr[128] = "qwe";
	char arr1[128]="rty";
	strcat(arr, arr1);
	printf("%s", arr);
	return 0;
}

运行结果
在这里插入图片描述
3.strstr

strstr()函数是一个参数为两个字符指针类型,返回值是char*类型的函数。

用于找到子串(str2)在一个字符串(str1)中第一次出现的位置(不包括str2的串结束符),并返回该位置的指针,如果找不到,返回空指针(NULL)。

这里因为传进来的地址指向的内容不会在发生改变,所以我们在两个形参(char*)前加上const。
它包含在string.h头文件中。

char* strstr(const char* str1,const char* str2)

例:

int main() {
	char arr[128] = "qwe";
	char arr1[128]="rtytrqwew";
	char * s=strstr(arr1, arr);
	printf("%s",s);
	return 0;
}

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

最后就是这道题的实现了

代码:

int findRound(const char* src, char* find)
{
	char tmp[256] = { 0 }; //用一个辅助空间将原字符串做成两倍原字符串
	strcpy(tmp, src); //先拷贝一遍
	strcat(tmp, src); //再连接一遍AABCDAABCD
	return strstr(tmp, find) != NULL; //看看找不找得到//真返回 1 ,假返回 0 
}
int main() {
	char arr[] = "AABCD";
	char arr1[] = "BCDAA";
	int n = strlen(arr);//求数组长度
	int i = findRound(arr,arr1);//调用
	printf("%d\n", i);//打印
	return 0;
}

时间复杂度为O(1),空间复杂度为O(n)

今天的分享就到这了,谢谢大家的观看

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/146319.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

深度学习 植物识别算法系统 计算机竞赛

文章目录 0 前言2 相关技术2.1 VGG-Net模型2.2 VGG-Net在植物识别的优势(1) 卷积核&#xff0c;池化核大小固定(2) 特征提取更全面(3) 网络训练误差收敛速度较快 3 VGG-Net的搭建3.1 Tornado简介(1) 优势(2) 关键代码 4 Inception V3 神经网络4.1 网络结构 5 开始训练5.1 数据集…

5个用于地理空间数据分析的Python包

大家好&#xff0c;地理空间数据分析在城市规划、环境研究、农业和交通等行业中至关重要。不断增长的需求导致Python包在各种地理数据分析要求上的使用增加&#xff0c;例如分析气候模式、研究城市发展或跟踪疾病传播等&#xff0c;评估和选择具有快速处理、修改和可视化能力的…

【移远QuecPython】EC800M物联网开发板的MQTT协议腾讯云数据上报

【移远QuecPython】EC800M物联网开发板的MQTT协议腾讯云数据上报 文章目录 导入库初始化设置MQTT注册回调订阅发布功能开启服务发送消息函数打包调用测试效果附录&#xff1a;列表的赋值类型和py打包列表赋值BUG复现代码改进优化总结 py打包 导入库 from TenCentYun import TX…

【Java】线程的调度、生命周期及状态转换

&#x1f33a;个人主页&#xff1a;Dawn黎明开始 &#x1f380;系列专栏&#xff1a;Java ⭐每日一句&#xff1a;夜色难免黑凉&#xff0c;前行必有曙光 &#x1f4e2;欢迎大家&#xff1a;关注&#x1f50d;点赞&#x1f44d;评论&#x1f4dd;收藏⭐️ ​ 文章目录 一.&…

day08_子网划分与子网掩码

什么是子网划分? 1、概念&#xff1a;借主机位给网络位使用,以此来达到把一个大网段划分为n个儿子网段的目的&#xff0c;2. 为何要进行子网划分&#xff1f;3、子网掩码&#xff1a;就是对ip地址打记号4、 网络地址的计算机方式&#xff1a;ip地址与子网掩码都转换成二进制&a…

链表面试题

&#x1f493;作者简介&#x1f44f;&#xff1a;在校大二迷茫大学生 &#x1f496;个人主页&#x1f389;&#xff1a;小李很执着 &#x1f497;系列专栏&#xff1a;Leetcode经典题 每日分享&#xff1a;其实要过那条马路并不难&#xff0c;就看谁在对面等你❣️❣️❣️ 目录…

MySQL数据库约束

目录 数据库约束 1.NULL约束 2.UNIQUE&#xff1a;唯一约束 3.DEFAULT&#xff1a;默认值约束 4.PRIMARY KEY&#xff1a;主键约束 5.FOREIGN KEY&#xff1a;外键约束 数据库约束 以下为本篇文章会介绍的约束 (1)NOT NULL - 指示某列不能存储 NULL 值。 (2)UNIQUE - …

Spark SQL编程

1. Spark SQL概述 1.1 什么是Spark SQL Spark SQL是用于结构化数据处理的Spark模块。与基本的Spark RDD API不同&#xff0c;Spark SQL提供的接口为Spark提供了有关数据结构和正在执行的计算的更多信息。在内部&#xff0c;Spark SQL使用这些额外的信息来执行额外的优化。与Spa…

qt+opengl 着色器VAO、VBO、EBO(四)

文章目录 一、顶点着色器和片段着色器代码分析1. 着色器12. 顶点着色器2 二、使用步骤1. 使用着色器12. 使用着色器23. 在着色器2中使用EBO 三、完整代码 一、顶点着色器和片段着色器代码分析 1. 着色器1 用到的坐标矩阵, 四个四边形顶点坐标 float vertices_data[36] {// 所…

PlantUML基础使用教程

环境搭建 IDEA插件下载 打开IEDA系列IDE&#xff0c;从FIle–>Settings–>Plugins–>Marketplace 进入到插件下载界面&#xff0c;搜索PlantUML&#xff0c;安装PlantUML Integration和PlantUML Parser两个插件&#xff0c;并重启IDE 安装和配置Graphviz 进入官网…

C/C++轻量级并发TCP服务器框架Zinx-框架开发001: 读取标准输入,回显到标准输出

文章目录 完整代码实现参考-非项目使用项目使用的代码 - 乱-但是思路与上面的相同创建Kernel类添加删除修改epoll&#xff0c;才能写run方法创建stdin_Channel类在Kernel类中实现run方法 完整代码实现参考-非项目使用 #include <errno.h> #include <signal.h> #in…

蓝桥杯每日一题2023.11.14

题目描述 题目分析 此题目的最终目标是将字母都填上数使等式符合条件&#xff0c;实际我们发现可以使用搜索将所有符合条件的进行判断&#xff08;答案&#xff1a;29&#xff09; 由于小数可能会出现错误故我们将其进行简单变化进行搜索 #include<bits/stdc.h> using…

No207.精选前端面试题,享受每天的挑战和学习

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入…

Pytorch自动混合精度的计算:torch.cuda.amp.autocast

1 autocast介绍 1.1 什么是AMP? 默认情况下&#xff0c;大多数深度学习框架都采用32位浮点算法进行训练。2017年&#xff0c;NVIDIA研究了一种用于混合精度训练的方法&#xff0c;该方法在训练网络时将单精度&#xff08;FP32&#xff09;与半精度(FP16)结合在一起&#xff…

Dart利用私有构造函数_()创建单例模式

文章目录 类的构造函数_()函数dart中构造函数定义 类的构造函数 类的构造函数有两种&#xff1a; 1&#xff09;默认构造函数&#xff1a; 当实例化对象的时候&#xff0c;会自动调用的函数&#xff0c;构造函数的名称和类的名称相同&#xff0c;在一个类中默认构造函数只能由…

post 和get参数 请求

json参数 post请求格式 RestController public class HelloController { //json参数 post 请求RequestMapping("/jsonParam")public String jsonParam(RequestBody User user){System.out.println(user);return "OK";} } postman 接口测试工具…

spring cloud alibaba 简介

微服务搭建组件选型 1.服务注册中心 Nacos(spring-cloud-alibaba) 2.服务通信 OpenFeign(spring-cloud) 3.服务熔断、降级、限流 Sentinel(spring-cloud-alibaba) 4.网关 Gateway(spring-cloud) 5.服务配置中心 …

MySQL被攻击后创建数据库报错1044 - Access denied for user ‘root‘@‘%‘ to database ‘xxx‘

MySQL被攻击后创建数据库报错1044 - Access denied for user root% to database xxx 一、问题二、解决过程1、正常过程2、踩坑&#xff08;已经解决问题的可以不看&#xff09; 一、问题 最近数据库被攻击了&#xff0c;业务数据库都没了 还好也不是有重要数据&#xff0c;但再…

【HUST】网安纳米|2023年研究生纳米技术考试参考

目录 1 纳米材料是什么 2 纳米材料的结构特性 3 纳米结构的其他特性 4 纳米结构的检测技术 5 纳米材料的应用 打印建议&#xff1a;PPT彩印&#xff08;这样重点比较突出&#xff09;&#xff0c;每面12张PPT&#xff0c;简单做一下关键词目录&#xff0c;亲测可以看清。如…

Uniapp开发 购物商城源码 在线电商商城源码 适配移动终端项目及各小程序

lilishop电商商城系统 商城移动端&#xff0c;使用Uniapp开发&#xff0c;可编译为所有移动终端项目及各小程序 源码下载&#xff1a;https://download.csdn.net/download/m0_66047725/88487579 源码下载2&#xff1a;关注我留言