【leetcode】C++_string 917.仅仅反转字母

打印 上一主题 下一主题

主题 1783|帖子 1783|积分 5349

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
1. 题目

给你一个字符串 s ,根据下述规则反转字符串:
   

  • 所有非英文字母保留在原有位置。
  • 所有英文字母(小写或大写)位置反转。
  • 返回反转后的 s 。
  示例1:
   输入:s = “ab-cd”
输出:“dc-ba”
  示例2:
   输入:s = “a-bC-dEf-ghIj”
输出:“j-Ih-gfE-dCba”
  示例3:
   输入:s = “Test1ng-Leet=code-Q!”
输出:“Qedo1ct-eeLg=ntse-T!”
  提示


  • 1 <= s.length <= 100
  • s 仅由 ASCII 值在范围 [33, 122] 的字符组成
  • s 不含 ’ \"’ 或 ‘\\’
  1. class Solution {
  2. public:
  3.         //判断字符是不是字母,是的话返回true,否则返回false
  4.     bool isLetter(char ch)
  5.     {
  6.         if(ch >= 'a' && ch <= 'z')
  7.             return true;
  8.         if(ch >= 'A' && ch <= 'Z')
  9.             return true;
  10.         return false;
  11.     }
  12.    
  13.     string reverseOnlyLetters(string s) {
  14.         if(s.empty())
  15.             return s;
  16.         int begin = 0, end = s.size() - 1;
  17.         while(begin < end)
  18.         {
  19.             while(begin < end && !isLetter(s[begin]))
  20.                 ++begin;
  21.             while(begin < end && !isLetter(s[end]))
  22.                 --end;
  23.             swap(s[begin], s[end]);
  24.             
  25.             ++begin;
  26.             --end;
  27.         }
  28.         
  29.         return s;
  30.     }
  31. };
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

南飓风

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表