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

反转字符串 反转字符串 || 反转字符串 |||

思想总结:首先将字符串转变为字符数组,再进行遍历并反转字符。

1.反转字符串

 代码:

class Solution {public void reverseString(char[] s) {reverse(s,0,s.length); //左闭右开}public static void reverse(char[] ch,int i,int j) { 翻转函数j = j-1;while(i<j) {char tmp = ch[i];ch[i] = ch[j];ch[j] = tmp;i++;j--;}}
}

2.反转字符串 ||

代码:

class Solution {public String reverseStr(String s, int k) {char[] arr = s.toCharArray();  //先将字符串 转换为 字符数组for(int i=0;i<s.length();i+=2*k) {if(i+k <= s.length()) {   //剩余的字符个数肯定大于kreverse(arr,i,i+k);  //左开右闭}else{reverse(arr,i,s.length()); //左开右闭 剩余字符少于k个的情况}   }return new String(arr);}public static void reverse(char[] ch,int i,int j) { //翻转函数j = j-1;while(i<j) {char tmp = ch[i];ch[i] = ch[j];ch[j] = tmp;i++;j--;}}
}

3.反转字符串中的单词 |||

可以双指针 也可以用栈来做

代码:

class Solution {/* //第一种 双指针public String reverseWords(String s) {char[] ch = s.toCharArray();int left = 0;  //  left保存每一次翻转的最开始位置int right=0;   //  right 保存每一次反转的结束位置for(;right<ch.length;right++) {if(ch[right]==' ') {reserve(ch,left,right);   //左开右闭left = right+1;}}reserve(ch,left,right);   //翻转最后一组字符串return new String(ch);  //字符数组转换为字符串}public static void reserve(char[] ch,int i ,int j) {  //自定义翻转函数j = j-1;while(i<j) {char tmp = ch[i];ch[i] = ch[j];ch[j] = tmp;i++;j--;}}*///2. 用栈来做public String reverseWords(String s) {Stack<Character> stack = new Stack<>();char[] ch = s.toCharArray();StringBuilder sb = new StringBuilder();for(int i = 0;i<ch.length;i++) {if(ch[i]!=' ') {stack.push(ch[i]);}else{while(!stack.isEmpty()) {sb.append(stack.pop());}sb.append(' ');}}while(!stack.isEmpty()) {sb.append(stack.pop());}return sb.toString();}}

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

相关文章:

  • XML解析 不允许有匹配 _[xX][mM][lL]_ 的处理指令目标
  • 【C++进阶(五)】STL大法--list模拟实现以及list和vector的对比
  • Docker安装RabbitMQ集群_亲测成功
  • 50道基础数据结构面试题
  • 【Linux基础】权限管理
  • C++初阶--类和对象(中)
  • 【MySQL系列】视图特性
  • 管理类联考——数学——汇总篇——知识点突破——应用题——最值问题
  • 学习SpringMvc第二战之【SpringMVC之综合案例】
  • 【算法日志】单调栈: 单调栈简介及其应用
  • VSCode自动分析代码的插件
  • 设计模式之外观模式
  • Web端测试和 App端测试有何不同?
  • 12.(Python数模)(相关性分析一)相关系数矩阵
  • 系统架构设计师(第二版)学习笔记----嵌入式系统及软件
  • Python列表操作指南:索引、切片、遍历与综合应用
  • 第15章_锁: MySQL并发访问相同记录以及从数据操作的类型划分锁(读锁、写锁)
  • PHP 排序函数使用方法,按照字母排序等操作
  • windows本地验证码识别工具
  • 修改图片尺寸的几个简单方法
  • 三、GoLang字符串的基本操作
  • 基于vue-cli创建后台管理系统前端页面——element-ui,axios,跨域配置,布局初步,导航栏
  • 在 ubuntu20.04 上安装 Pytorch
  • 远程恋爱网站部署秘籍——群晖虚拟机助ni秀恩爱
  • vscode c++解决包含头文件红色波浪线问题
  • PostgreSQL docker compose安装配置
  • 电脑文件批量重命名:高效操作技巧
  • c高级day4(shell)
  • 整十粉丝庆祝文章系列内容征集建议
  • 两数乘积:输出1~100整数乱序列表中两数乘积是目标整数的最小下标对