(B卷,100分)- 代码编辑器(Java & JS & Python)

题目描述

某公司为了更高效的编写代码,邀请你开发一款代码编辑器程序。

程序的输入为 已有的代码文本和指令序列,程序需输出编辑后的最终文本。指针初始位置位于文本的开头。
支持的指令(X为大于等于0的整数, word 为无空格的字符串):

  • FORWARD X 指针向前(右)移动X,如果指针移动位置超过了文本末尾,则将指针移动到文本末尾
  • BACKWARD X 指针向后(左)移动X,如果指针移动位置超过了文本开头,则将指针移动到文本开头
  • SEARCH-FORWARD word 从指针当前位置向前查找 word 并将指针移动到word的起始位置,如果未找到则保持不变
  • SEARCH-BACKWARD word 在文本中向后查我 word 并将指针移动到word的起始位置,如果未找到则保持不变
  • INSERT word 在指针当前位置前插入word,并将指针移动到word的结尾
  • REPLACE word 在指针当前位置替换并插入字符(删除原有字符,并增加新的字符)
  • DELETE X 在指针位置删除X个字符

输入描述

输入的第一行为命令列表的长度K

输入的第二行为文件中的原始文本

接下来的K行,每行为一个指令

输出描述

编辑后的最终结果

备注

文本最长长度不超过 256K

用例

输入 1
ello
INSERT h
输出 hello
说明 在文本开头插入
输入 2
hllo
FORWARD 1
INSERT e
输出 hello
说明 在文本的第一个位置插入
输入 2
hell
FORWARD 1000
INSERT o
输出 hello
说明 在文本的结尾插入
输入 1
hello
REPLACE HELLO
输出 HELLO
说明 替换
输入 1
hello
REPLACE HELLO_WORLD
输出 HELLO_WORLD
说明 超过文本长度替换
输入 2
hell
FORWARD 10000
REPLACE O
输出 hellO
说明 超出文本长度替换

题目解析

本题考察逻辑分析,以及字符串常用操作。

本题题目描述对逻辑描述的非常清晰,大家可以对照题目描述来看下面的代码。

其中,容易出错的点是:

  • SEARCH-BACKWARD 是向后查找,这个“向后”,其实是“向左”
  • SEARCH-FORWARD 是向前查找,这个“向前”,其实是“向右”
  • 假设指针位置是curIdx,原始文本是s,SEARCH-BACKWARD word,即相当于在s的0~curIdx范围反向查找word,这里容易出错的点是反向查找方法参数的含义,大家可以看下各自语言的下面方法参数的含义
Java lastIndexOf
JS lastIndexOf String.prototype.lastIndexOf() – JavaScript | MDN (mozilla.org)
Python rfind Python rfind()方法 | 菜鸟教程 (runoob.com)

 

  • INSERT word,这里容易出错的点是,插入word到s中后,curIdx也要更新位置到插入word的最后一个单词位置后面

JS算法源码

/* JavaScript Node ACM模式 控制台输入获取 */
const readline = require("readline");

const rl = readline.createInterface({
  input: process.stdin,
  output: process.stdout,
});

const lines = [];
let k, s;
rl.on("line", (line) => {
  lines.push(line);

  if (lines.length == 2) {
    k = parseInt(lines[0]);
    s = lines[1];
  }

  if (k && lines.length == k + 2) {
    lines.shift();
    lines.shift();
    const commands = lines.map((str) => str.split(" "));

    console.log(getResult(s, commands));

    lines.length = 0;
  }
});

function getResult(s, commands) {
  let curIdx = 0;

  for (let [type, value] of commands) {
    switch (type) {
      case "FORWARD":
        curIdx += parseInt(value);
        curIdx = Math.min(curIdx, s.length);
        break;
      case "BACKWARD":
        curIdx -= parseInt(value);
        curIdx = Math.max(curIdx, 0);
        break;
      case "SEARCH-FORWARD":
        const i = s.indexOf(value, curIdx);
        if (i != -1) curIdx = i;
        break;
      case "SEARCH-BACKWARD":
        const i1 = s.lastIndexOf(value, curIdx);
        if (i1 != -1) curIdx = i1;
        break;
      case "INSERT":
        tmp = [...s];
        tmp.splice(curIdx, 0, ...value);
        s = tmp.join("");
        curIdx += value.length;
        break;
      case "REPLACE":
        tmp = [...s];
        tmp.splice(curIdx, value.length, ...value);
        s = tmp.join("");
        break;
      case "DELETE":
        tmp = [...s];
        tmp.splice(curIdx, parseInt(value));
        s = tmp.join("");
        break;
    }
  }

  return s;
}

Java算法源码

import java.util.Scanner;

public class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int k = Integer.parseInt(sc.nextLine());

    StringBuilder s = new StringBuilder(sc.nextLine());

    String[][] commands = new String[k][2];
    for (int i = 0; i < k; i++) {
      commands[i] = sc.nextLine().split(" ");
    }

    System.out.println(getResult(s, commands));
  }

  public static String getResult(StringBuilder s, String[][] commands) {
    int curIdx = 0;

    for (String[] command : commands) {
      switch (command[0]) {
        case "FORWARD":
          curIdx += Integer.parseInt(command[1]);
          curIdx = Math.min(curIdx, s.length());
          break;
        case "BACKWARD":
          curIdx -= Integer.parseInt(command[1]);
          curIdx = Math.max(curIdx, 0);
          break;
        case "SEARCH-FORWARD":
          int i = s.indexOf(command[1], curIdx);
          if (i != -1) curIdx = i;
          break;
        case "SEARCH-BACKWARD":
          int i1 = s.lastIndexOf(command[1], curIdx);
          if (i1 != -1) curIdx = i1;
          break;
        case "INSERT":
          s.insert(curIdx, command[1]);
          curIdx += command[1].length();
          break;
        case "REPLACE":
          s.replace(curIdx, curIdx + command[1].length(), command[1]);
          break;
        case "DELETE":
          s.delete(curIdx, curIdx + Integer.parseInt(command[1]));
          break;
      }
    }

    return s.toString();
  }
}

Python算法源码

# 输入获取
k = int(input())
s = input()
commands = list(input().split() for _ in range(k))


# 算法入口
def getResult():
    global s

    curIdx = 0

    for type, value in commands:
        if type == "FORWARD":
            curIdx += int(value)
            curIdx = min(curIdx, len(s))
        elif type == "BACKWARD":
            curIdx -= int(value)
            curIdx = max(curIdx, 0)
        elif type == "SEARCH-FORWARD":
            i = s.find(value, curIdx)
            if i != -1:
                curIdx = i
        elif type == "SEARCH-BACKWARD":
            j = s.rfind(value, 0, curIdx)
            if j != -1:
                curIdx = j
        elif type == "INSERT":
            lst = list(s)
            lst.insert(curIdx, value)
            s = "".join(lst)
            curIdx += len(value)
        elif type == "REPLACE":
            lst = list(s)
            del lst[curIdx:curIdx + len(value)]
            lst.insert(curIdx, value)
            s = "".join(lst)
        elif type == "DELETE":
            lst = list(s)
            del lst[curIdx:curIdx + int(value)]
            s = "".join(lst)

    return s


# 算法调用
print(getResult())

免责声明:

1、IT资源小站为非营利性网站,全站所有资料仅供网友个人学习使用,禁止商用
2、本站所有文档、视频、书籍等资料均由网友分享,本站只负责收集不承担任何技术及版权问题
3、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除下载链接并致以最深的歉意
4、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
5、一经注册为本站会员,一律视为同意网站规定,本站管理员及版主有权禁止违规用户
6、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和IT资源小站的同意
7、IT资源小站管理员和版主有权不事先通知发贴者而删除本文

0

评论0

站点公告

没有账号?注册  忘记密码?