返回介绍

solution / 1600-1699 / 1678.Goal Parser Interpretation / README_EN

发布于 2024-06-17 01:03:15 字数 6840 浏览 0 评论 0 收藏 0

1678. Goal Parser Interpretation

中文文档

Description

You own a Goal Parser that can interpret a string command. The command consists of an alphabet of "G", "()" and/or "(al)" in some order. The Goal Parser will interpret "G" as the string "G", "()" as the string "o", and "(al)" as the string "al". The interpreted strings are then concatenated in the original order.

Given the string command, return _the Goal Parser's interpretation of _command.

 

Example 1:

Input: command = "G()(al)"
Output: "Goal"
Explanation: The Goal Parser interprets the command as follows:
G -> G
() -> o
(al) -> al
The final concatenated result is "Goal".

Example 2:

Input: command = "G()()()()(al)"
Output: "Gooooal"

Example 3:

Input: command = "(al)G(al)()()G"
Output: "alGalooG"

 

Constraints:

  • 1 <= command.length <= 100
  • command consists of "G", "()", and/or "(al)" in some order.

Solutions

Solution 1: String Replacement

According to the problem, we only need to replace "()" with 'o' and "(al)" with "al" in the string command.

class Solution:
  def interpret(self, command: str) -> str:
    return command.replace('()', 'o').replace('(al)', 'al')
class Solution {
  public String interpret(String command) {
    return command.replace("()", "o").replace("(al)", "al");
  }
}
class Solution {
public:
  string interpret(string command) {
    while (command.find("()") != -1) command.replace(command.find("()"), 2, "o");
    while (command.find("(al)") != -1) command.replace(command.find("(al)"), 4, "al");
    return command;
  }
};
func interpret(command string) string {
  command = strings.ReplaceAll(command, "()", "o")
  command = strings.ReplaceAll(command, "(al)", "al")
  return command
}
function interpret(command: string): string {
  return command.replace(/\(\)/g, 'o').replace(/\(al\)/g, 'al');
}
impl Solution {
  pub fn interpret(command: String) -> String {
    command.replace("()", "o").replace("(al)", "al")
  }
}
char* interpret(char* command) {
  int n = strlen(command);
  char* ans = malloc(sizeof(char) * n + 1);
  int i = 0;
  for (int j = 0; j < n; j++) {
    char c = command[j];
    if (c == 'G') {
      ans[i++] = 'G';
    } else if (c == '(') {
      if (command[j + 1] == ')') {
        ans[i++] = 'o';
      } else {
        ans[i++] = 'a';
        ans[i++] = 'l';
      }
    }
  }
  ans[i] = '\0';
  return ans;
}

Solution 2: String Iteration

We can also iterate over the string command. For each character $c$:

  • If it is 'G', directly add $c$ to the result string;
  • If it is '(', check if the next character is ')'. If it is, add 'o' to the result string. Otherwise, add "al" to the result string.

After the iteration, return the result string.

The time complexity is $O(n)$, and the space complexity is $O(1)$.

class Solution:
  def interpret(self, command: str) -> str:
    ans = []
    for i, c in enumerate(command):
      if c == 'G':
        ans.append(c)
      elif c == '(':
        ans.append('o' if command[i + 1] == ')' else 'al')
    return ''.join(ans)
class Solution {
  public String interpret(String command) {
    StringBuilder ans = new StringBuilder();
    for (int i = 0; i < command.length(); ++i) {
      char c = command.charAt(i);
      if (c == 'G') {
        ans.append(c);
      } else if (c == '(') {
        ans.append(command.charAt(i + 1) == ')' ? "o" : "al");
      }
    }
    return ans.toString();
  }
}
class Solution {
public:
  string interpret(string command) {
    string ans;
    for (int i = 0; i < command.size(); ++i) {
      char c = command[i];
      if (c == 'G')
        ans += c;
      else if (c == '(')
        ans += command[i + 1] == ')' ? "o" : "al";
    }
    return ans;
  }
};
func interpret(command string) string {
  ans := &strings.Builder{}
  for i, c := range command {
    if c == 'G' {
      ans.WriteRune(c)
    } else if c == '(' {
      if command[i+1] == ')' {
        ans.WriteByte('o')
      } else {
        ans.WriteString("al")
      }
    }
  }
  return ans.String()
}
function interpret(command: string): string {
  const n = command.length;
  const ans: string[] = [];
  for (let i = 0; i < n; i++) {
    const c = command[i];
    if (c === 'G') {
      ans.push(c);
    } else if (c === '(') {
      ans.push(command[i + 1] === ')' ? 'o' : 'al');
    }
  }
  return ans.join('');
}
impl Solution {
  pub fn interpret(command: String) -> String {
    let mut ans = String::new();
    let bs = command.as_bytes();
    for i in 0..bs.len() {
      if bs[i] == b'G' {
        ans.push_str("G");
      }
      if bs[i] == b'(' {
        ans.push_str({
          if bs[i + 1] == b')' { "o" } else { "al" }
        });
      }
    }
    ans
  }
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文