【漫步刷题路】- 逆序字符串II

简介: 【漫步刷题路】- 逆序字符串II

🚀题目要求:

字符串:I love you

逆序后结果: you love me


🥇逆置法

假设逆置: Man  Max

->整体逆置:  xaM naM

->分别逆置  对xaM逆置:Max

                    对naM逆置:Man

->最终结果为: Max Man


🚖思路:

  • 先整体逆置
  • 定义两个指针,一个start,一个end,end负责移动。遇到字符串的空格就停下来,逆置[start,end-1]区间字符的内容 然后end和start指向end+1的位置。再继续寻找空格
  • 当end遇到的是\0,说明已经到了字符串的尾了,退出循环

🥫图解


🍔代码

#include<stdio.h>
#include<assert.h>
#include<string.h>
//区间逆置
void reverse(char* left, char* right)
{
  assert(left && right);
  while (left < right)
  {
    char str = *right;
    *right = *left;
    *left = str;
    right--;
    left++;
  }
}
int main()
{
  char str[100] = "Chase the wisdom 99";
  int len = strlen(str);
  //1.先整体逆置
  reverse(str, str + len - 1);
  //2.分别逆置,以空格为分隔 
  char* end = str;
  char* start = str;
    //循环判断条件:end指向的字符不是\0
  while (*end != '\0')
  {
        //当end没有遇到\0 和空格就继续
    while ( (*end != '\0')  && (*end != ' '))
    {
      end++;
    }
        //当end跳出循环时,指向的就是空格或者\0  逆置[start,end-1]的内容
    reverse(start, end-1);
        //end向后移动,进行下一次循环
        //start从end位置开始,重新定义起始区间
        end++;
    start = end;
  }
  printf(str);
  return 0;
}



相关文章
|
2月前
|
算法
Leetcode第十四题(最长公共前缀)
这篇文章介绍了一种算法,用于在给定的字符串数组中找到最长公共前缀,通过逐字符比较每个字符串的对应位置,一旦发现不匹配立即返回当前已匹配的子串作为公共前缀。
29 0
|
7月前
|
人工智能 算法 Java
每日一刷《剑指offer》字符串篇之编辑距离
每日一刷《剑指offer》字符串篇之编辑距离
68 0
每日一刷《剑指offer》字符串篇之编辑距离
|
7月前
|
Java
每日一刷《剑指offer》字符串篇之左旋转字符串
每日一刷《剑指offer》字符串篇之左旋转字符串
59 0
每日一刷《剑指offer》字符串篇之左旋转字符串
|
7月前
|
Java
每日一题《剑指offer》字符串篇之字符串的排列
每日一题《剑指offer》字符串篇之字符串的排列
81 0
每日一题《剑指offer》字符串篇之字符串的排列
|
7月前
|
Java 测试技术 Python
每日一题《剑指offer》字符串篇之表示数值的字符串
每日一题《剑指offer》字符串篇之表示数值的字符串
52 0
每日一题《剑指offer》字符串篇之表示数值的字符串
|
7月前
|
人工智能 Java
每日一题《剑指offer》数组篇之连续子数组的最大和
每日一题《剑指offer》数组篇之连续子数组的最大和
60 0
每日一题《剑指offer》数组篇之连续子数组的最大和
|
7月前
|
Java
每日一题《剑指offer》字符串篇之替换空格
每日一题《剑指offer》字符串篇之替换空格
59 0
每日一题《剑指offer》字符串篇之替换空格
|
7月前
|
人工智能 算法 Java
截断数组(蓝桥杯每日一题)
截断数组(蓝桥杯每日一题)
50 0
|
存储 算法 Serverless
代码随想录算法训练营第六天 | LeetCode 242.有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和
代码随想录算法训练营第六天 | LeetCode 242.有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和
74 0
代码随想录算法训练营第六天 | LeetCode 242.有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和
|
算法
代码随想录算法训练营第八天 | LeetCode 344.反转字符串、541. 反转字符串II、剑指Offer 05.替换空格、151.翻转字符串里的单词、剑指Offer58-II.左旋转字符串
代码随想录算法训练营第八天 | LeetCode 344.反转字符串、541. 反转字符串II、剑指Offer 05.替换空格、151.翻转字符串里的单词、剑指Offer58-II.左旋转字符串
63 0