【C语言】字符函数和字符串函数(二)—>函数应用实例

简介: 【C语言】字符函数和字符串函数(二)—>函数应用实例

前言:

本篇承接上篇所学,主要利用所学知识进行应用实践,看一看字符函数对于某些问题的求解技巧。

什么是旋转字符串?

旋转字符串分为左旋和右旋两种,比如左旋字符串就是从前面k个字符将其拼接到尾部,右旋字符串就是后面k个字符将其拼接到头部。

旋转字符串的四种解法:

(一)解法1—>逐个拼接法

逐个拼接法就是每次以一个字符为操作对象逐个移动字符的过程。

代码实现:

void leftRound(char* src, int time)
{
  int i, j, tmp;
  int len = strlen(src);
  time %= len; 
  for (i = 0; i < time; i++) //执行k次的单次平移
  {
    tmp = src[0];
    for (j = 0; j < len - 1; j++) //单次平移
    {
      src[j] = src[j + 1];
    }
    src[j] = tmp;
  }
}

关于time%=len;

当字符串长度为5的情况下,旋转6、11、16...次相当于1次,7、12、17...次相当于2次,以此类推。

那么我们可不可以想办法将操作对象从单个字符改为两个整体,一个为待旋转字符串,一个为剩余字符串呢,这样就不需要逐个字符处理了,请看整体拼接法。

(二)解法2—>整体拼接法

思路类似两个数据利用中间变量交换位置。

代码实现:

void leftRound(char* src, int time)
{
  int len = strlen(src);
  int pos = time % len; //断开位置的下标
  char tmp[256] = { 0 }; //更准确的话可以选择malloc len + 1个字节的空间来做这个tmp
  strcpy(tmp, src + pos); //先将后面的全部拷过来
  strncat(tmp, src, pos); //然后将前面几个接上
  strcpy(src, tmp); //最后拷回去
}

利用刚刚学习的字符函数辅助实现。

(三)解法3—>三步翻转法

三步翻转法十分巧妙,只需要将待旋转字符串逆序,再将剩余字符串逆序,最后整体字符串逆序就得到了旋转后的字符串。

比如ABCDEF,假设我需要左旋AB,那么:

  1. 将待旋转字符串AB逆序,得到BA。
  2. 将剩余字符串CDEF逆序,得到FEDC。
  3. 将重组的整体字符串BAFEDC逆序,得到CDEFAB。

还是ABCDEF,我需要右旋EF,那么:

  1. 将待旋转字符串EF逆序,得到FE。
  2. 将剩余字符串ABCD逆序,得到DCBA。
  3. 将重组的整体字符串DCBAFE逆序,得到EFABCD。

代码实现:

void reverse_part(char *str, int start, int end) //将字符串从start到end这一段逆序
{
    int i, j;
  char tmp;
  for (i = start, j = end; i < j; i++, j--)
  {
    tmp = str[i];
    str[i] = str[j];
    str[j] = tmp;
  }
}
void leftRound(char * src, int time)
{
  int len = strlen(src);
  int pos = time % len;
  reverse_part(src, 0, pos - 1); //逆序前段
  reverse_part(src, pos, len - 1); //逆序后段
  reverse_part(src, 0, len - 1); //整体逆序
}

(四)解法4—>追加判断法

追加判断法同样十分巧妙,但更加简洁,假设我们用笨方法将所有旋转字符串的结果罗列出来,就会发现:

ABCDEF无论怎么旋,旋转后的所有结果,都包含在了ABCDEFABCDEF这个字符串里了。

所以做法很简单,只需要将原字符串再来一遍接在后面,然后找一找待查找的字符串是不是两倍原字符串的子集即可。

代码实现:

int findRound(const char* src, char* find)
{
  char tmp[256] = { 0 }; //用一个辅助空间将原字符串做成两倍原字符串
  strcpy(tmp, src); //先拷贝一遍
  strcat(tmp, src); //再连接一遍
  return strstr(tmp, find) != NULL; //看看找不找得到
}

总结解题规律,积累解题方法对于学习过程至关重要,希望以上内容对读者们字符串知识的掌握有所帮助,关注博主不迷路🔥🔥🔥

目录
相关文章
|
10天前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
25 3
|
1天前
|
存储 缓存 C语言
【c语言】简单的算术操作符、输入输出函数
本文介绍了C语言中的算术操作符、赋值操作符、单目操作符以及输入输出函数 `printf` 和 `scanf` 的基本用法。算术操作符包括加、减、乘、除和求余,其中除法和求余运算有特殊规则。赋值操作符用于给变量赋值,并支持复合赋值。单目操作符包括自增自减、正负号和强制类型转换。输入输出函数 `printf` 和 `scanf` 用于格式化输入和输出,支持多种占位符和格式控制。通过示例代码详细解释了这些操作符和函数的使用方法。
17 10
|
5天前
|
存储 编译器 C语言
C语言函数的定义与函数的声明的区别
C语言中,函数的定义包含函数的实现,即具体执行的代码块;而函数的声明仅描述函数的名称、返回类型和参数列表,用于告知编译器函数的存在,但不包含实现细节。声明通常放在头文件中,定义则在源文件中。
|
10天前
|
C语言
C语言函数
C语言函数
10 0
|
11天前
|
C语言
c语言回顾-函数递归(上)
c语言回顾-函数递归(上)
27 2
|
13天前
|
Java 编译器 C语言
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
16 3
|
16天前
|
存储 程序员 编译器
C语言——动态内存管理与内存操作函数
C语言——动态内存管理与内存操作函数
|
16天前
|
C语言
C语言字符(串)函数
C语言字符(串)函数
|
16天前
|
C语言
C语言函数返回值详解
本文详细解析了C语言中函数返回值的概念与应用。从函数的基本定义入手,深入探讨了不同类型返回值的作用及意义,并提供了实用的编程示例,帮助读者更好地理解和使用函数返回值。通过本文,你将掌握如何有效利用返回值优化代码结构与功能实现。
|
11天前
|
C语言 C++
c语言回顾-内存操作函数
c语言回顾-内存操作函数
34 0