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

C语言——oj刷题——字符串左旋

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

例如:

ABCD左旋一个字符得到BCDA

ABCD左旋两个字符得到CDAB


实现:
当我们谈到字符串左旋时,我们指的是将字符串中的字符向左移动一定数量的位置。这个问题在编程中非常常见,特别是在字符串处理和算法实现中。

在C语言中,我们可以使用一种简单而有效的方法来完成字符串的左旋操作。下面是一个示例代码,演示了如何实现字符串左旋:

#include <stdio.h>
#include <string.h>void reverse(char* str, int start, int end) {while (start < end) {char temp = str[start];str[start] = str[end];str[end] = temp;start++;end--;}
}void leftRotateString(char* str, int k) {int len = strlen(str);k = k % len;  // 处理k大于字符串长度的情况reverse(str, 0, k - 1);  // 反转前k个字符reverse(str, k, len - 1);  // 反转剩余的字符reverse(str, 0, len - 1);  // 整体反转字符串
}int main() {char str[] = "abcdefg";int k = 2;  // 左旋2个位置printf("原始字符串: %s\n", str);leftRotateString(str, k);printf("左旋后的字符串: %s\n", str);return 0;
}

在上面的示例代码中,我们定义了两个辅助函数:reverse和leftRotateString。

reverse函数用于反转字符串中指定范围内的字符。它使用两个指针(start和end)来遍历字符串,交换对应位置上的字符,直到两个指针相遇。

leftRotateString函数是实现字符串左旋的核心函数。它首先计算旋转位置k与字符串长度的余数,以处理k大于字符串长度的情况。然后,它分别对前k个字符、剩余字符和整个字符串进行反转操作,最终完成字符串的左旋。

在main函数中,我们定义了一个示例字符串"abcdefg"和旋转位置k为2。我们先打印出原始字符串,然后调用leftRotateString函数进行左旋操作,最后打印出左旋后的字符串。


运行上述代码,输出将是:

原始字符串: abcdefg
左旋后的字符串: cdefgab

这就是用C语言完成字符串左旋的方法和示例代码。希望对你有所帮助!如果有任何问题,请随时提问。

http://www.lryc.cn/news/299541.html

相关文章:

  • 神经网络(Nature Network)
  • 【Unity】QFramework通用背包系统优化:使用Odin优化编辑器
  • 基本算法--贪心
  • 13. 串口接收模块的项目应用案例
  • Python re找到特定pattern并将此pattern重复n次
  • ChatGpt报错:We ran into an issue while authenticating you解决办法
  • 如何从 iPhone 恢复已删除的视频:简单有效方法
  • 【python量化交易】qteasy使用教程02 - 获取和管理金融数据
  • 数据库学习案例20240206-ORACLE NEW RAC agent and resource关系汇总。
  • TypeScript 入门
  • linux 磁盘相关操作
  • PyTorch: torch.max()函数详解
  • Rust基础拾遗--核心功能
  • MySQL:常用指令
  • Scrapy:Python中强大的网络爬虫框架
  • linux系统非关系型数据库redis的配置文件
  • 电力负荷预测 | 基于LSTM、TCN的电力负荷预测(Python)
  • Java+SpringBoot实习管理系统探秘
  • c入门第十六篇——学生成绩管理系统
  • 大文件上传如何做断点续传?
  • SpringCloud-Eureka原理分析
  • LeetCode周赛——384
  • C#,巴都万数列(Padonve Number)的算法与源代码
  • NSSCTF Round#18 RE GenshinWishSimulator WP
  • 鸿蒙系统对应安卓版本
  • 算法-16-并查集
  • 【C/C++】2024春晚刘谦春晚魔术步骤模拟+暴力破解
  • Java运算符和表达式
  • 波奇学Linux:软硬链接
  • HTTP网络通信协议基础