C:每日一题:字符串左旋

题目:实现一个函数,可以实现字符串的左旋

例如:ABCD左旋一个字符就是BCDA;ABCD左旋两个字符就是CDAB;

1、解题思路:

1.确定目标旋转k个字符,我们要获取字符串的长度 len,目的是根据长度来处理 k 可能超出字符串长度的情况;

2.创建一个函数 left 来实现字符串左旋;

3.对k进行取模运算:k%=len,该表达式目的是计算实际旋转次数。假设字符串长度是 5,而要左旋 7 个字符,实际上相当于左旋 7 % 5 = 2 个字符。

4.创建一个临时数组 temp 来存放要左旋的 k 个字符,防止后续移动字符串时数据丢失。

5.使用 strncpy 将字符串前 k 个字符复制到 temp 中,使用 memmove 函数移动字符串,把从第 k 个字符开始的部分向前移动 k 个位置。(等会简单介绍一下函数的使用)

6.使用 strncat 函数将保存在 temp 中的前 k 个字符拼接到移动后的字符串后面,完成左旋操作。

2、知识补充:

注:这里就简单介绍一下用法,能让大家读懂我后面写的代码,后面会专门出一篇文章来介绍这些函数。以下介绍的函数使用都需要加上头文件<string.h>

1、strncpy

strncpy是字符串复制函数,作用是将指定数量的字符从源字符串复制到目标字符串。

函数原型:char *strncpy(char *dest, const char *src, size_t n)

  • dest:目标字符串。
  • src :源字符串。
  • n :要复制的最大字符数。

使用:

#include <stdio.h>
#include <string.h>
int main() {char dest[10];char src[] = "Hello";strncpy(dest, src, 2);  // 复制 src 的前 2 个字符到 destdest[2] = '\0';  // 手动添加字符串结束符printf("%s\n", dest);  // 输出 "He"return 0;
}

2.memmove

memmove是内存操作函数,作用是将 n个字节的数据从 src 所指向的内存区域复制到 dest 所指向的内存区域,可以处理源内存区域和目标内存区域重叠的情况,保证正确地复制数据。

函数原型:void *memmove(void *dest, const void *src, size_t n)

  • dest:指向目标内存区域的指针,数据将被移动到这里。
  • src:指向源内存区域的指针,数据将从此处移动。
  • n :要移动的字节数。

使用:

#include <stdio.h>
#include <string.h>int main() {char str[] = "HelloWorld";memmove(str + 5, str, 5);printf("%s\n", str); return 0;
}

3.strncat 

 strncat是字符拼接函数,作用是将源字符串 scr 中的最多 n 个字符拼接到目标字符串 dest 的末尾,并在拼接后的字符串末尾自动添加字符串结束符 '\0'

函数原型:char *strncat(char *dest, const char *src, size_t n)(同上)

使用:

#include <stdio.h>
#include <string.h>int main() {char dest[20] = "Hello, ";char src[] = "World!";strncat(dest, src, 5);  // 拼接 src 的前 5 个字符printf("%s\n", dest);  // 输出 "Hello, World"return 0;
}

3、代码展示及解析:

#include <stdio.h>
#include <string.h>
void left(char* str, int k)//完成字符左旋操作
{int len = strlen(str);k %= len;//实际左旋次数char temp[2];//这里使用2表示是因为在vs2022上表达式必须含有常量值strncpy(temp, str, k);//复制要左旋的k个字符到临时数组temp中memmove(str, str + k, len - k);//移动字符串str[len - k] = '\0';//确保完整性strncat(str, temp, k);//将存储在 temp 中的前 k 个字符拼接到移动后的字符串后面
}
int main()
{char str[] = "abcd";int k = 2;//左旋个数为2printf("左旋前:%s\n", str);left(str, k);//实现左旋操作的函数调用printf("左旋后:%s\n", str);return 0;
}

char temp[2]这是由于vs2022不支持变长数组才这样写的代码,如果你所使用的编译器支持边长数组,可以改进一下代码

代码改进:

#include <stdio.h>
#include <string.h>
void left(char* str, int k)
{int len = strlen(str);k %= len;char temp[k];//变长数组strncpy(temp, str, k);memmove(str, str + k, len - k);str[len - k] = '\0';strncat(str, temp, k);
}
int main()
{char str[] = "abcd";int k = 2;printf("左旋前:%s\n", str);left(str, k);printf("左旋后:%s\n", str);return 0;
}

 

如果在支持变长数组,这样写代码会更加的方便,你只需要修改所输入k的值就可以实现左旋不同个字符,例如:输入k=1,左旋一个字符;输入k=2,左旋两个字符。

4、不使用这些库函数来实现字符串左旋

代码及注释:(这个是结合老师的讲解所写的)

#include <stdio.h>
// 左旋字符串函数
void left(char* str, int k)
{int len = 0;  // 存储字符串长度char* p = str;  //遍历字符串计算长度while (*p) // 计算字符串长度{len++;p++;}k %= len;  // 实际左旋次数for (int i = 0; i < k; i++)  // 进行左旋操作{char temp = *str;  // 保存字符串要左旋的k个字符  for (int j = 0; j < len - 1; j++)  // 将字符串从第二个字符开始依次向前移动一位{*(str + j) = *(str + j + 1);}*(str + len - 1) = temp;  // 将保存的k个字符放到字符串尾部}
}
int main() 
{char str[] = "ABCD";int k = 2;printf("左旋前: %s\n", str);left(str, k);printf("左旋后: %s\n", str);return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PyCharm单步调试

1、先在入口设置断点&#xff0c;再点击爬虫图标&#xff08;shift F9&#xff09;开始调试 调试图标如图&#xff1a; 2、蓝色光标表示当前运行在这行 3、快捷键 F7&#xff1a;进入当前行函数 F8&#xff1a;单步 F9&#xff1a;全速运行

Nuclei文件上传小Tips

前言 Nuclei对于文件上传类型Poc编写小Tips 平台 ProjectDiscovery Cloud Platform: https://cloud.projectdiscovery.io/ JsonPath: https://jsonpath.com/ Json解析&#xff1a; 在线json解析平台即可 案例 某康resourceOperations upload接口存在前台上传 具体接口&…

财务会计与管理会计(十一)

文章目录 快速切换日记账余额SUMPRODUCT、LOOKUP函数应用 销售业绩分段统计表SUMPRODUCT函数的应用 自动打印发票签收单VLOOKUP函数的应用 快速切换日记账余额 SUMPRODUCT、LOOKUP函数应用 C2SUMPRODUCT((A5:A100B2)*C5:C100) D2SUMPRODUCT((A5:A100B2)*D5:D100) E4公式1&…

【时时三省】(C语言基础)数据的额存储

山不在高&#xff0c;有仙则名。水不在深&#xff0c;有龙则灵。 ----CSDN 时时三省 例题1: i>0恒成立 会进入死循环 因为unsigned是无符号数 所以不可能会有负数 就会进入死循环 注意:i打印的时候如果它上面类型是无符号数 但是打印是%d 它会打印有符号数 例题:2 这个循…

集团数字化转型方案(二)

集团数字化转型方案通过整合物联网&#xff08;IoT&#xff09;、大数据分析、人工智能&#xff08;AI&#xff09;和云计算技术&#xff0c;构建了一个全面智能化的业务平台&#xff0c;从而实现了全集团范围内的业务流程自动化、数据驱动决策优化、以及客户体验的个性化提升。…

如何利用Jmeter从0到1做一次完整的压测

压测&#xff0c;在很多项目中都有应用&#xff0c;是测试小伙伴必备的一项基本技能&#xff0c;刚好最近接手了一个小游戏的压测任务&#xff0c;一轮压测下来&#xff0c;颇有收获&#xff0c;赶紧记录下来&#xff0c;与大家分享一下&#xff0c;希望大家能少踩坑。 一、压…

【Py Error002】python rarfile解压 Cannot find working tool

1.欢迎点赞、关注、批评、指正&#xff0c;互三走起来&#xff0c;小手动起来&#xff01; 2.了解、学习Python批量解压zip、rar压缩包文件&#xff0c;并结合日常的场景进行测试。 文章目录 1.问题详情2.解决办法3.参考链接 1.问题详情 Python代码解压rar压缩包报错&#xff…

秃姐学AI系列之:池化层 + 代码实现

目录 池化层 二维最大池化层 Max Pooling 池化层超参数 平均池化层 Mean Pooling 总结 代码实现 池化层 卷积对位置非常敏感的&#xff0c;但是我们在实际应用中我们需要一定程度的平移不变性。比如照明、物体位置、比例、外观等因素会导致图片发生变化。所以卷积对未…

ollama使用llama3.1案例

ollama安装和运行llama3.1 8b conda create -n ollama python3.11 -y conda activate ollama curl -fsSL https://ollama.com/install.sh | sh ollama run songfy/llama3.1:8b 就这么简单就能运行起来了. 我们可以在命令行中与他交互. 当然我们也可以用接口访问: curl http:…

DQL-案例

一.题目: 1&#xff09;分析: 1.有 姓名 &#xff0c;性别&#xff0c;入职时间(需要开始时间和结束时间-->范围查询); 2.右下角有分页条-->需要分页展示 2&#xff09;创建表的代码&#xff1a; -- 员工管理 create table emp (id int unsigned primary ke…

linux知识

内核是操作系统的核心部分&#xff0c;它是基于硬件的第一层软件扩充&#xff0c;提供操作系统的最基本功能&#xff0c;是操作系统工作的基础。内核的主要职责包括管理系统的进程、内存、设备驱动程序、文件和网络系统等&#xff0c;这些功能共同决定了系统的性能和稳定性。 …

武汉流星汇聚:西班牙时尚消费高涨,中国商家借亚马逊平台拓商机

在2024年第二季度的亚马逊西班牙站&#xff0c;一场前所未有的时尚盛宴正悄然上演。销售额同比高增长TOP10品类榜单的揭晓&#xff0c;不仅揭示了西班牙消费者对于时尚品类的狂热追求&#xff0c;更为亚马逊平台上的中国商家开启了一扇通往新蓝海的大门。其中&#xff0c;男士拳…

极速闪存启动:SD与SPI模式的智能初始化指南

最近很多客户朋友在询问我们 CS 创世 SD NAND 能不能使用 SPI 接口&#xff0c;两者使用起来有何区别&#xff0c;下面为大家详细解答。 SD MODE: CS 创世 SD NAND 支持 SD 模式和 SPI 模式&#xff0c;SD NAND 默认为 SD 模式&#xff0c;上电后&#xff0c;其初始化过程如下…

系统架构:分而治之

系统架构&#xff1a;分而治之 引言“分而治之”在架构中的应用模块化设计分层化架构微服务架构 分而治之的优势降低复杂性提高灵活性和可扩展性增强可维护性促进团队协作 分而治之的劣势复杂性转移性能开销开发和运维的复杂性数据一致性挑战 结论 引言 “分而治之”是一种分析…

python开发--乌龟对对碰实现(一)

文章目录 前言规则解析代码实现代码解析问题总结与思考 前言 "乌龟对对碰"是一种近期在网络直播平台上非常流行的盲盒玩法&#xff0c;消费者购买盲袋或盲盒&#xff0c;每个包含一个不同颜色的树脂乌龟玩具。玩家在购买时会许愿一个特定颜色的乌龟&#xff0c;卖家…

虚幻5|AI视力系统,听力系统,预测系统(1)视力系统

继宠物伴随系统初步篇后续 虚幻5|AI巡逻宠物伴随及定点巡逻—初步篇-CSDN博客 一&#xff0c;听力系统 1.打开宠物ai的角色蓝图 2.选中ai感知组件 右侧细节&#xff0c;找到ai感知&#xff0c;添加感知配置&#xff0c;我们需要的是ai视力配置 3.选中左侧创建的ai感知组件&…

分组汇总时保留不变列

Excel表格的ID列是分类&#xff0c;Value1和Value2是数值&#xff0c;ID相同时Descr 1和Descr 2保持不变。 ABCDE1IDValue 1Value 2Descr 1Descr 22112.51.8ax13112.31.1ax14111.91.6ax15123.73.5bx26123.91.5bx27132.50.2cx38132.64.1cx391324.8cx310132.71.8cx3 要求&#…

科创中心“核”动力|趋动科技:AI算力界的领跑者

近日&#xff0c;趋动科技与深信服正式推出联合解决方案。联合解决方案将深信服EDS的高性能存储与趋动科技OrionX AI算力资源池化软件、以及GeminiAI训练平台有机结合&#xff0c;整合存力与算力资源的同时&#xff0c;帮助用户建好AI平台、管好AI资源、用好AI服务。 双方已完成…

【嵌入式烧录刷写文件】-2.10-为一个Intel Hex文件计算校验和Checksum

案例背景(共6页精讲): 有如下一段Intel Hex文件&#xff0c;为其创建Checksum校验和&#xff1a;CRC16&#xff0c;CRC32(CVN)&#xff0c;SHA-256 Hash算法…, 将Checksum Value填充到指定地址。 :2091000058595A5B5C5D5E5F606162636465666768696A6B6C6D6E6F707172737475767…

Unity 求坐标点在扇形区域内的投影

视频效果&#xff1a; 代码: /// <summary>/// 投影在扇形区域内的点/// </summary>/// <param name"targetPos">目标点</param>/// <param name"fanRadius">扇形半径</param>/// <param name"fanAngle"…