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

路径加密(替换空格),剑指offer,力扣

目录

我们直接看题解吧:

方法: 

审题目+事例+提示:

解题思路:

法1:

 代码(法1):

法2:

代码(法2):


原题解:

【剑指Offer】2、替换空格 

   力扣题解:

         LCR 122. 路径加密 - 力扣(LeetCode)

今天刷路径加密(替换空格),大家有兴趣可以点上看看题目要求,试着做一下

我们直接看题解吧:

由于力扣题目与原题有点差异,力扣传入的是String,而原题这边传的是StringBuffer,所以这边以原题为主

方法: 

第一个方法,创建新字符串

(剑指offer)第二个方法,原地更改

审题目+事例+提示:

原题中时将空格“ ”改为%20,这意味着每次需要增加两位

解题思路:

法1:

循环,遇到‘.’(空格)就加空格“ ”(%20),否则就其他加字符。

 代码(法1):

力扣:

class Solution:def pathEncryption(self, path: str) -> str:res = []for c in path:if c == '.': res.append(' ')else: res.append(c)return "".join(res)

 原题:

   public String replaceSpace(StringBuffer str) {String res="";for(int i=0;i<str.length();i++){char c=str.charAt(i);if(c==' ')res += "%20";elseres += c;}return res;}

优化1(利用三目运算):

class Solution {
public:string replaceSpace(string s) {string str;for(int i = 0;i<s.size();i++){s[i]==' '?str+="%20":str+=s[i];}return str;}
};

优化2(利用replace()方法):

class Solution {public String replaceSpace(String s) {return s.replaceAll(" ","%20");}
}
法2:
  1. 判断数组是否为空,是则返回null
  2. 循环统计一下空格数量
  3. 设置数组新长度,双指针,oldindex指向原数组末尾,newindex指向原数组+2*空数量
  4. 循环:

         ·若遇到空格,oldindex--,依次newindex--,填入%,2,0

       ·否则,将其他字符元素放入new指向的位置,之后old与new 递减

    5.最后返回字符串

代码(法2):
   public String replaceSpace(StringBuffer str) {if(str==null)return null;int numOfblank = 0;//空格数量int len=str.length();for(int i=0;i<len;i++){  //计算空格数量if(str.charAt(i)==' ')numOfblank++;}str.setLength(len+2*numOfblank); //设置长度int oldIndex=len-1;  //两个指针int newIndex=(len+2*numOfblank)-1;while(oldIndex>=0 && newIndex>oldIndex){char c=str.charAt(oldIndex);if(c==' '){oldIndex--;str.setCharAt(newIndex--,'0');str.setCharAt(newIndex--,'2');str.setCharAt(newIndex--,'%');}else{str.setCharAt(newIndex,c);oldIndex--;newIndex--;}}return str.toString();}

注:使用 了setLength()、setCharAt()方法

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

相关文章:

  • HarmonyOS开发:UI开展前的阶段总结
  • Linux安装Libreoffice
  • 如何将系统盘MBR转GPT?无损教程分享!
  • 基于element-plus定义表单配置化
  • LeetCode算法题解(贪心)|LeetCode122. 买卖股票的最佳时机 II、LeetCoed55. 跳跃游戏、LeetCode45. 跳跃游戏 II
  • 计蒜客详解合集(2)期
  • 华为防火墙vrrp+hrp双机热备主备备份(两端为交换机)
  • Angular 由一个bug说起之一:List / Grid的性能问题
  • 第12章 PyTorch图像分割代码框架-3:推理与部署
  • MYSQL---基础篇
  • 【启扬方案】启扬安卓屏一体机在医疗自助服务终端上的应用解决方案
  • 收藏!7个国内「小众」的程序员社区
  • LeetCode(4)删除有序数组中的重复项 II【数组/字符串】【中等】
  • C++ 同构字符串/ 单词规律
  • oracle 中 %TYPE %ROWTYPE
  • Pytorch实战教程(五)-计算机视觉基础
  • 51单片机PCF8591数字电压表数码管显示设计( proteus仿真+程序+设计报告+讲解视频)
  • 普华永道于进博会首发“企业数据资源会计处理一体化平台”
  • IDEA 使用Reset Current Branch to Here 进行git 版本控制,图文操作
  • 有趣的 TCP 抢带宽行为
  • HCIP---VRRP
  • 在家用Python搞副业,也能月入10000+
  • play() failed because the user didn‘t interact with the document first.
  • Java任意视频转MP4
  • flutter实践:慎用Expanded
  • 华为防火墙vrrp+hrp双机热备负载分担(两端为交换机)
  • 欧拉角(横滚角、俯仰角、偏航角)、旋转矩阵、四元数的转换与解决万向节死锁
  • Java Post请求参数格式为XML
  • Windows 安装 JDK 8 和 JDK 17 和多版本JDK切换
  • SpringData、SparkStreaming和Flink集成Elasticsearch