题解 | #机器人的运动范围#

字典树的实现

http://www.nowcoder.com/practice/a55a584bc0ca4a83a272680174be113b

思想很简单,但是超过时间了

import java.util.*;


public class Solution {
    /**
     * 
     * @param operators string字符串二维数组 the ops
     * @return string字符串一维数组
     */
    //operators[0][0] - 1,operators[0][1] - qwer
    //StringBuilder lastStr = new StringBuilder();
    ArrayList<String> lastStr = new ArrayList<String>();
    ArrayList<String> res = new ArrayList<String>();
    public String[] trieU (String[][] operators) {
        // write code here
        int len = operators.length;
        
        for(int i = 0;i<len;i++){
            String str = operators[i][0];
            switch(str){
                case "1":insert(operators[i][1]);
                    break;
                case "2":delete(operators[i][1]);
                    break;    
                case "3":search(operators[i][1]);
                    break;      
                case "4":prefixNumber(operators[i][1]);
                    break;   
            }//System.out.println(lastStr);
        }
        
        return res.toArray(new String[]{});
    }
    //1.增加
    public void insert(String word){
        lastStr.add(word);
    }
    //2.删除
    public void delete(String word){
        lastStr.remove(String.valueOf(word));
    }
    //3.查询
    public boolean search(String word){
        if(lastStr.indexOf(word)!=-1){
            res.add("YES");
            return true;
        }
        res.add("NO");
        return false;
    }
    //4.出现次数
    public int prefixNumber(String pre){
        int cnt = 0;
        for(int i = 0;i<lastStr.size();i++){
            if(lastStr.get(i).length() < pre.length()) continue;
            if(lastStr.get(i).substring(0, pre.length()).equals(pre)){
                cnt ++;
            }
        }
        res.add(cnt+"");
        return cnt;  
    }
}
全部评论

相关推荐

03-17 23:54
黑龙江大学 Java
来个白菜也好啊qaq:可以的,大厂有的缺打手
点赞 评论 收藏
分享
昨天 08:58
已编辑
门头沟学院 Java
ttl:&nbsp;3.19一面晚上过3.20二面3.23oc3.25offerbase:末9有一段中小厂实习一面面经:(总体时长一个小时二十分钟左右没什么八股,主要都是问项目和场景题1.实习(问了有四十分钟,感觉面试官很看重实习这一块,一直在拷打,问到后面我都要疯了,好在准备得比较充分1️⃣用的是什么中间件,有参与技术选型吗,实习的项目里为什么选这个RabbitMQ而不是kafka,为什么不用RocketMQ,为什么放弃异步,自己的项目里面使用的是kafka,那你觉得项目和实习的中间件选型有差异的原因是什么,他们之间的区别在哪里,底层的原因知道吗(高柱到这里已经快疯了,但是硬着头皮答完了,主要是从一致性吞吐量和框架的契合度答,面试官说答得挺好的,应该是没什么问题,这一块就问了快半个小时,到这里我已经快疯了2️⃣项目怎么对接上下游3️⃣介绍项目的难点重点4️⃣微服务(高柱实习是单体项目没涉及这一块5️⃣Redis的使用2.项目:1️⃣智能客服是怎么应用在项目里的(langchain4j➕rag➕functioncalling)2️⃣RAG了解多少3️⃣文本向量化的难点是什么,了解哪些大模型的知识(我一点不懂,纯瞎扯,但貌似扯对了4️⃣对ai的态度是什么,aicoding相关5️⃣怎么保证多节点下Caffeine缓存里面数据都是一致的(答的是短ttl,面试官不是很满意,但是我确实不太懂这个怎么保证,后来查了还是不懂怎么保证6️⃣Redis的使用,和你的实习项目的使用有区别吗,还有一些引申问题3.八股(含量不高,就是走个过场1️⃣进程的内存布局2️⃣Redis三剑客3️⃣微服务相关知识(高柱已经忘得差不多了…勉强答上来4️⃣JVM5️⃣线程状态6️⃣线程安全,在你的实习项目里怎么保证线程安全的(又绕回来了4.智商题找异常球5.手撕:1️⃣五道sql,不难2️⃣力扣不重叠的滑动窗口数组,贪心➕双指针秒了强度拉满了这个一面,高柱到后面人都是傻的二面面经:(就半个小时实习拷打,简历上写了几点就问了几点,问完就结束了,无手撕
查看19道真题和解析
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务