【华为机考真题】字符串压缩

这里写自定义目录标题

部分通过,请问该咋改

给定一段英文句子和一个英文单词列表。英文句子包含英文单词和标点符号,

其中:

1)英文单词只包含[a-zA-Z]范围内的字符

2)标点符号包括逗号,句号,双引号(双引号两边至少有一个空格)

如果列表中有单词在句子中存在(大小写不敏感)且该单词未被双引号包含,则使用该单词在列表中的索引值(索引值从0开始)代替句子中的该单词

如果英文单词列表存在重复的英文单词,则该单词最后出现英文单词

解答要求:

时间限制:C/C++400ms,其他语言:800ms

内存限制:C/c++200MB,其他语言:400MB

输入:

第一行,一段英文句子

第二行,英文单词列表

提示:每个英文单词长度在[1-50]范围内

输入的英文句子长度在[0,10000]范围内

输入英文单词列表长度在[0,10000]范围内

英文句子不会出现双引号不匹配的情况

输出:

替换后的英文句子

样例1

bash 复制代码
输入: Hello world.
      Good Hello LOOP
输出: 1 world.
解释:hello在英文句子中存在,则使用hello的索引值进行替换,得到结果1 world.```、
样例2

```bash
输入: An introduction is "the first paragraph" of your paper. 
      what say first Second IS introduction IS end
      
输出: An 5 6 "the first paragraph" of your paper.
解释:字符串列表中的introduction,IS在句子中存在,first虽然在句子中存在但被双引号包含了,所以使用introduction单词,IS单词(最后一次出现)的索引值进行替换,得到的结果为 An 5 6 "the first paragraph " of your papger

本人写的代码如下,但只是部分用例,还需修改,但不知如何进行修改,请有经验的同学解答一下。

部分通过代码如下所示:

java 复制代码
import java.util.*;
import java.io.*;
public class Test {

    private  static  String replaceWithIndex(String sentences,List<String> worldlist){

        String[] words = sentences.split("\\s+");
        StringBuilder replaceSentence = new StringBuilder();
        for (String word: words){
            // word = word.replaceAll("[^a-zA-Z]","");
            int index= worldlist.indexOf(word);
            if(index != -1){
                replaceSentence.append(index).append(" ");
            }else {
                replaceSentence.append(word).append(" ");
            }
        }
        return replaceSentence.toString().trim();
    }




    public static void main(String[] args) throws IOException {

        Scanner sc = new Scanner(System.in);

        String sentences = sc.nextLine();
        String str = sc.nextLine();
        List<String> wordList = new ArrayList<>();
        for(String word : str.split("\\s+") ){

            wordList.add(word);

        }


        String replaceSentences = replaceWithIndex(sentences,wordList);
        System.out.println(replaceSentences);
        sc.close();

    }
}
相关推荐
CDwenhuohuo14 小时前
前端文件预览
开发语言·前端·javascript
charlie11451419114 小时前
通用GUI编程技术——图形渲染实战(三十八)——顶点缓冲与输入布局:GPU的第一个三角形
开发语言·c++·学习·图形渲染·win32
IT猿手14 小时前
SCI一区:章鱼优化算法(Octopus Optimization Algorithm, OOA)求解23个测试函数,出图丰富,提供完整MATLAB代码
开发语言·算法·matlab
程序员JerrySUN14 小时前
Jetson边缘嵌入式实战课程第二讲:JetPack 和 SDK Manager 是什么
c语言·开发语言·网络·udp·音视频
不知名的老吴14 小时前
后端知识点:Python处理加权点赞
开发语言·python
IntMainJhy14 小时前
「Flutter三方库sqflite的鸿蒙化适配与实战指南:从入门到踩坑的本地数据库开发全记录」
数据库·flutter·华为·信息可视化·数据库开发·harmonyos
海参崴-14 小时前
C++ STL篇 AVL树的模拟实现
开发语言·c++
Cyber4K14 小时前
【Python专项】基础语法(2)
开发语言·python
亦暖筑序14 小时前
AI 客服系统安全加固:JWT 鉴权 + Bucket4j 三层限流
java·架构
xhuiting14 小时前
项目技术总结
java