首页 > 其他分享 >【116】

【116】

时间:2022-11-06 11:24:35浏览次数:42  
标签:String al replace 116 command 字符串 Goal

1678. 设计 Goal 解析器  

请你设计一个可以解释字符串 command 的 Goal 解析器 。command 由 "G""()" 和/或 "(al)" 按某种顺序组成。Goal 解析器会将 "G" 解释为字符串 "G""()" 解释为字符串 "o" ,"(al)" 解释为字符串 "al" 。然后,按原顺序将经解释得到的字符串连接成一个字符串。

给你字符串 command ,返回 Goal 解析器 对 command 的解释结果。

 

示例 1:

输入:command = "G()(al)"
输出:"Goal"
解释:Goal 解析器解释命令的步骤如下所示:
G -> G
() -> o
(al) -> al
最后连接得到的结果是 "Goal"

示例 2:

输入:command = "G()()()()(al)"
输出:"Gooooal"

示例 3:

输入:command = "(al)G(al)()()G"
输出:"alGalooG"
---------------------------------------------------------------------------------------------------
直接遍历
 1 class Solution {
 2     public String interpret(String command) {
 3         StringBuilder sb = new StringBuilder();
 4         String s = command;
 5         for(int i = 0;i < s.length();i++){
 6             char ch = s.charAt(i);
 7             if(ch == 'G'){
 8                 sb.append('G');
 9             }if(ch == '(' && s.charAt(i+1) == ')'){
10                 sb.append('o');
11             }else if(ch == '(' && s.charAt(i+1) == 'a'){
12                 sb.append("al");
13             }
14         }
15         return sb.toString();
16     }
17 }
---------------------------------------------------------------------------------------------------
调用String类的replace函数
String 和 StringBuilder中都有replace方法,今天我们来看看。
String:
String replace(char oldChar, char newChar)
用新字符newChar 替换所有的 旧字符oldChar 。

String replace(CharSequence target, CharSequence replacement)
用新字符串replacement替换所有的 旧字符串target。

String replaceAll(String regex, String replacement)
用新字符串replacement 替换所有的 正则模式匹配的串。——(替换的是模糊字串)

String replaceFirst(String regex, String replacement)
用新字符串replacement 替换第一个 正则模式匹配的串。——(替换的是模糊字串)

StringBuilder:
replace(int start,int end,String str)
用str 替换 start–end的子串。//不包括end
————————————————
版权声明:本文为CSDN博主「小码哥222」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_38737586/article/details/99224148
1 class Solution {
2     public String interpret(String command) {
3         return command.replace("()" , "o").replace("(al)", "al");
4     }
5 }

 

标签:String,al,replace,116,command,字符串,Goal
From: https://www.cnblogs.com/wzxxhlyl/p/16862228.html

相关文章

  • CF1163D Mysterious Code ACA+DP
    将两个串插入AC自动机,AC自动机带点权,S串带权值1,T串带权值-1,对树在构建时求树上点权前缀和,然后设表示到的第个字符,在ACA上的第个节点时的答案,那么就有转移方程:#include<bits......
  • uva 1169
    地图上有n个点(x,y),机器人从(0,0)出发到每个点捡垃圾(w[i]),承载最大重量为m在每个点都可以返回(0,0)点放置垃圾最短路程?n<1e5,m<100 看完范围只能设f[i],考虑前i......
  • 力扣 116. 填充每个节点的下一个右侧节点指针 [无queue]
    116.填充每个节点的下一个右侧节点指针给定一个 完美二叉树 ,其所有叶子节点都在同一层,每个父节点都有两个子节点。二叉树定义如下:structNode{intval;No......
  • 第116期:二次确认提示框开(类似popConfirm)发示例
    封面图魔女宅急便剧照背景在某个项目中,传统的二次弹框总是使用一个大的modal来进行,对界面的流程有一定的阻断效果。同时,用户看到弹框习惯直接点击确认按钮,导致操作失误。分......
  • P1165 日志分析
    日志分析题目描述\(M\)海运公司最近要对旗下仓库的货物进出情况进行统计。目前他们所拥有的唯一记录就是一个记录集装箱进出情况的日志。该日志记录了两类操作:第一类操......
  • CF1163F Indecisive Taxi Fee
    题意给定一张无向图,每次询问为更改一条边的边权后,从\(1\)到\(n\)的最短路。Solution首先考虑有哪些情况。如果原图中\(1\ton\)的最短路为路径\(P\),其上第\(i\)......
  • 【luogu CF1163F】Indecisive Taxi Fee(图论)(分类讨论)
    IndecisiveTaxiFee题目链接:luoguCF1163F题目大意给你一个无向图,每次改一条边的权值(每次都会变回来),问你1~n的最短路长度。思路考虑分类讨论,先找到最短路的路径,然......
  • 116. 填充每个节点的下一个右侧节点指针
    题目描述给定一个 完美二叉树 ,其所有叶子节点都在同一层,每个父节点都有两个子节点。二叉树定义如下:structNode{intval;Node*left;Node*right;Node*n......
  • 116. 填充每个节点的下一个右侧节点指针
    /*//DefinitionforaNode.classNode{public:intval;Node*left;Node*right;Node*next;Node():val(0),left(NULL),right(NULL),n......
  • LeetCode 1116. Print Zero Even Odd
    原题链接在这里:https://leetcode.com/problems/print-zero-even-odd/题目:Youhaveafunction printNumber thatcanbecalledwithanintegerparameterandprints......