C语言题解——倒置字符串(剑指Offer 第58题)

简介: C语言题解——倒置字符串(剑指Offer 第58题)

🏅前言


在《剑指Offer》中有这样一道经典题目:

6e8e5f5aa81b7a07a30c9ecbeeaae6a.png


图片来源:2021-10-18 剑指offer2:49~58题目+思路+多种题解_Can__er的博客-CSDN博客

大概意思就是将一句话倒置(左旋),单词位置翻转,但单词内字母不翻转。


比如:I like beijing.  左旋后变成 : beijing. like I


可以看到各单词间的空格依然存在,并且字符串总长度保持不变。


很多同学看到这个题目有点懵,不知道从何下手,甚至还产生了把字符串中的单词分别放入不同的数组中,然后再打印的想法,想法不错,可惜并不灵活,万一有N个单词呢?


下面由我带大家学习一下这题的解法:

🏅正文



题目要求输入一句话(字符串),说明需要用数组存储,而且因为由空格,不能使用scanf,这里我们改用gets(arr)存储字符串;字符串有结束标志 '\0',我们可以利用strlen函数求出长度,这样我们就得到了数组名(首元素地址)、数组长度、数组尾元素地址,数组此时已经被拿捏了,可以进行操作了。


fddb73f8bbb977e83fd7404a0108217.png

//字符串倒置
#include<stdio.h>
#include<string.h>
#include<assert.h>
void reverse(char* left, char* right)
{
  assert(left && right);//断言,防止空指针
  while (left < right)
  {
    char tmp = *left;
    *left = *right;
    *right = tmp;
    left++;
    right--;
  }
}
int main()
{
  char arr[101] = { 0 };
  gets(arr);//获取字符
  int len = strlen(arr);
  reverse(arr, arr+len-1);//第一次翻转
  char* str = arr;//起点指针
  char* end = arr;//终点指针
  char* cur = arr;//结束指针
  while (*cur)
  {
    while (*end != ' ' && *end != '\0')
    {
      end++;
    }
    reverse(str, end - 1);
    str = end + 1;
    if (*end == '\0')
      cur = end;
    else
      cur = end++;
  }
  printf("%s\n", arr);
  return 0;
}

以上便是此题的解析,翻转再翻转的操作值得深思,起点、终点指针的位置也要注意更新。


🏅总结


  这题我在写的时候花了很多时间,主要卡在两点上:1.死磕 scanf输入   2.第二次翻转的时候指针用的太少了,导致位置更新是个大麻烦,顶多能翻转第一个单词。当我受到启发后,发现可以

多用些指针来辅助定位时,这题自然就迎刃而解了,所以想跟大家分享下这题的解法。


 如果你觉得本文写的还不错的话,期待留下一个小小的赞👍,你的支持是我分享的最大动力!


 如果本文有不足或错误的地方,随时欢迎指出,我会在第一时间改正!

10d6d91a45662f0545016527fcaa4f8.png


目录
相关文章
|
1月前
|
存储 C语言 开发者
【C语言】字符串操作函数详解
这些字符串操作函数在C语言中提供了强大的功能,帮助开发者有效地处理字符串数据。通过对每个函数的详细讲解、示例代码和表格说明,可以更好地理解如何使用这些函数进行各种字符串操作。如果在实际编程中遇到特定的字符串处理需求,可以参考这些函数和示例,灵活运用。
72 10
|
2月前
|
存储 算法 C语言
C语言中常见的字符串处理技巧,包括字符串的定义、初始化、输入输出、长度计算、比较、查找与替换、拼接、截取、转换、遍历及注意事项
本文深入探讨了C语言中常见的字符串处理技巧,包括字符串的定义、初始化、输入输出、长度计算、比较、查找与替换、拼接、截取、转换、遍历及注意事项,并通过案例分析展示了实际应用,旨在帮助读者提高编程效率和代码质量。
134 4
|
3月前
|
C语言 C++
【C语言】解决不同场景字符串问题:巧妙运用字符串函数
【C语言】解决不同场景字符串问题:巧妙运用字符串函数
|
4月前
|
存储 C语言
【C语言基础考研向】10 字符数组初始化及传递和scanf 读取字符串
本文介绍了C语言中字符数组的初始化方法及其在函数间传递的注意事项。字符数组初始化有两种方式:逐个字符赋值或整体初始化字符串。实际工作中常用后者,如`char c[10]=&quot;hello&quot;`。示例代码展示了如何初始化及传递字符数组,并解释了为何未正确添加结束符`\0`会导致乱码。此外,还讨论了`scanf`函数读取字符串时忽略空格和回车的特点。
129 8
|
4月前
|
存储 Serverless C语言
【C语言基础考研向】11 gets函数与puts函数及str系列字符串操作函数
本文介绍了C语言中的`gets`和`puts`函数,`gets`用于从标准输入读取字符串直至换行符,并自动添加字符串结束标志`\0`。`puts`则用于向标准输出打印字符串并自动换行。此外,文章还详细讲解了`str`系列字符串操作函数,包括统计字符串长度的`strlen`、复制字符串的`strcpy`、比较字符串的`strcmp`以及拼接字符串的`strcat`。通过示例代码展示了这些函数的具体应用及注意事项。
274 7
|
4月前
|
存储 人工智能 C语言
C语言程序设计核心详解 第八章 指针超详细讲解_指针变量_二维数组指针_指向字符串指针
本文详细讲解了C语言中的指针,包括指针变量的定义与引用、指向数组及字符串的指针变量等。首先介绍了指针变量的基本概念和定义格式,随后通过多个示例展示了如何使用指针变量来操作普通变量、数组和字符串。文章还深入探讨了指向函数的指针变量以及指针数组的概念,并解释了空指针的意义和使用场景。通过丰富的代码示例和图形化展示,帮助读者更好地理解和掌握C语言中的指针知识。
164 4
|
4月前
|
C语言
C语言 字符串操作函数
本文档详细介绍了多个常用的字符串操作函数,包括 `strlen`、`strcpy`、`strncpy`、`strcat`、`strncat`、`strcmp`、`strncpy`、`sprintf`、`itoa`、`strchr`、`strspn`、`strcspn`、`strstr` 和 `strtok`。每个函数均提供了语法说明、参数解释、返回值描述及示例代码。此外,还给出了部分函数的自实现版本,帮助读者深入理解其工作原理。通过这些函数,可以轻松地进行字符串长度计算、复制、连接、比较等操作。
|
5月前
|
C语言
【C语言】字符串及其函数速览
【C语言】字符串及其函数速览
37 4
|
5月前
|
C语言
【C语言篇】字符和字符串以及内存函数详细介绍与模拟实现(下篇)
perror函数打印完参数部分的字符串后,再打印⼀个冒号和⼀个空格,再打印错误信息。
71 0
|
5月前
|
存储 安全 编译器
【C语言篇】字符和字符串以及内存函数的详细介绍与模拟实现(上篇)
当然可以用scanf和printf输入输出,这里在之前【C语言篇】scanf和printf万字超详细介绍(基本加拓展用法)已经讲过了,这里就不再赘述,主要介绍只针对字符的函数.
62 0