一、500. Keyboard Row

给定一个单词列表,只返回可以使用在键盘同一行的字母打印出来的单词。
输入: ["Hello", "Alaska", "Dad", "Peace"]
输出: ["Alaska", "Dad"]
可以重复使用键盘上同一字符。
可以假设输入的字符串将只包含字母。

  思路:将键盘上每一行的字母映射到所在的行数,如果单词的所有字母中存在和第一个单词所在的行数不相同的字母,则这个单词将不是符合需求的单词。

  需要注意的地方:

  1.whichRow = -1;以及 if (whichRow != -1) list.add(s);这种表示,可以少使用一个boolean类型的标识位,同样可以实现效果。

  2.List<String> list = new ArrayList<>();以及return list.toArray(new String[0]);的表达,由于collection.toArray(T[] a)方法转换过来是Object类型的数组,使用new String[0]可以在转换之前提前说明转换之后的类型,就是开辟了一块长度为0的内存用来做标记的作用。

    public String[] findWords(String[] words) {
String[] rows = {"qwertyuiop", "asdfghjkl", "zxcvbnm"};
Map<Character, Integer> map = new HashMap<>();
for (int i = 0; i < rows.length; i++) {
for (char c : rows[i].toCharArray()) {
map.put(c, i);
}
}
List<String> list = new ArrayList<>();
for (String s : words) {
int whichRow = map.get(s.toLowerCase().charAt(0));
for (int i = 1; i < s.length(); i++) {
if (map.get(s.toLowerCase().charAt(i)) != whichRow) {
whichRow = -1;
break;
}
}
if (whichRow != -1) list.add(s);
}
return list.toArray(new String[0]);
}

  二、690. Employee Importance

给定一个保存员工信息的数据结构,它包含了员工唯一的id,重要度 和 直系下属的id。
比如,员工1是员工2的领导,员工2是员工3的领导。
他们相应的重要度为15, 10, 5。那么员工1的数据结构是[1, 15, [2]],员工2的数据结构是[2, 10, [3]],员工3的数据结构是[3, 5, []]。
注意虽然员工3也是员工1的一个下属,但是由于并不是直系下属,因此没有体现在员工1的数据结构中。
现在输入一个公司的所有员工信息,以及单个员工id,返回这个员工和他所有下属的重要度之和。
输入: [[1, 5, [2, 3]], [2, 3, []], [3, 3, []]], 1
输出: 11
员工1自身的重要度是5,他有两个直系下属2和3,而且2和3的重要度均为3。因此员工1的总重要度是 5 + 3 + 3 = 11。
一个员工最多有一个直系领导,但是可以有多个直系下属。员工数量不超过2000。

  1.类似于[[1, 5, [2, 3]], [2, 3, []], [3, 3, []]], 1这种情况,可以使用下面的代码,只计算了当前的员工和其直系下属的重要值之和。

    public int getImportance(List<Employee> employees, int id) {
int res = 0;
int boss = -1;
for (int i = 0; i < employees.size(); i++) {
if (employees.get(i).id == id) {
boss = i;
res += employees.get(i).importance;
}
}
if (boss == -1) return 0;
for (int i = 0; i < employees.size(); i++) {
if (employees.get(boss).subordinates.contains(employees.get(i).id)) {
res += employees.get(i).importance;
}
}
return res;
}

  而如果是[[1, 5, [2, 3]],[2, 3, [4]],,[3, 3, []], 4,1,[]], 1这种情况就无法计算了。但是如果画图来看,它就是一个二叉树,因此考虑深度优先遍历。(DFS)

  2.思路:使用Map:e.id -> e,然后再使用DFS遍历即可。

  需要注意的地方:使用Map是为了在DFS的时候可以很方便地用id来表示对象,注意DFS的表达ans += dfs(subid);

    private Map<Integer, Employee> map;

    public int getImportance(List<Employee> employees, int id) {
map = new HashMap<>();
for (Employee employee : employees) map.put(employee.id, employee);
return dfs(id);
} private int dfs(int id) {
Employee employee = map.get(id);
int ans = employee.importance;
for (Integer subid : employee.subordinates) {
ans += dfs(subid);
}
return ans;
}

  三、447. Number of Boomerangs

给定平面上 n 对不同的点,“回旋镖” 是由点表示的元组 (i, j, k) ,其中 i 和 j 之间的距离和 i 和 k 之间的距离相等(需要考虑元组的顺序)。
输入:
[[0,0],[1,0],[2,0]]
输出:
2
两个回旋镖为 [[1,0],[0,0],[2,0]] 和 [[1,0],[2,0],[0,0]]

  1.思路:首先使用暴力法遍历出每一个点到除了它本身的其他点的距离,例如,假设遍历到了[0,0]这个点,对于其他每个点到[0,0]的距离做为key,出现的次数作为value,也就是说,如果[0,0]对应的map为{1=1,2=3,3=4},就说明到[0,0]的距离为1的点有1个,为2的点有2个,为3的点有4个,那么表示回旋镖的时候,[0,0]为第一个,剩下两个数排列,即A21 + A22 + A32 = 1*0 + 2*1+3*2=8;

  2.代码(时间复杂度N^2,空间复杂度N):需要注意的表达是:for (int value : map.values()) count += value * (value-1);和 map.clear();,前者不用通过map.keyset()来遍历,这样可以更加快捷,直接使用map里面的value也可以满足想要的需求;后者每次clear可以再次重复使用,这样只需要新建一个Map对象就可以重复使用。

    public int numberOfBoomerangs(int[][] points) {
int count = 0;
Map<Integer, Integer> map = new HashMap<>();
for (int i = 0; i < points.length; i++) {
for (int j = 0; j < points.length; j++) {
if (i == j) continue;
int d = getDistance(points[i], points[j]);
map.put(d, map.getOrDefault(d, 0)+1);
}
for (int value : map.values()) count += value * (value-1);
map.clear();
}
return count;
} private int getDistance(int[] a, int[] b) {
int dx = a[0] - b[0];
int dy = a[1] - b[1];
return dx*dx + dy*dy;
}

  四、720. Longest Word in Dictionary(TODO)

输入:
words = ["w","wo","wor","worl", "world"]
输出: "world"
解释:
单词"world"可由"w", "wo", "wor", 和 "worl"添加一个字母组成。 输入:
words = ["a", "banana", "app", "appl", "ap", "apply", "apple"]
输出: "apple"
解释:
"apply"和"apple"都能由词典中的单词组成。但是"apple"得字典序小于"apply"。

  1.思路:(1)Brute Force (2)Trie + DFS

  2.代码:

  五、438. Find All Anagrams in a String

输入:
s: "cbaebabacd" p: "abc"
输出:
[0, 6]
解释:
起始索引等于 0 的子串是 "cba", 它是 "abc" 的字母异位词。
起始索引等于 6 的子串是 "bac", 它是 "abc" 的字母异位词。 输入:
s: "abab" p: "ab"
输出:
[0, 1, 2]
起始索引等于 0 的子串是 "ab", 它是 "ab" 的字母异位词。
起始索引等于 1 的子串是 "ba", 它是 "ab" 的字母异位词。
起始索引等于 2 的子串是 "ab", 它是 "ab" 的字母异位词。

  1.思路:(1)Brute Force[Time Limit Exceeded]  (2)Sliding Window(TODO)

  2.代码:

  (1)Brute Force[Time Limit Exceeded]

    public List<Integer> findAnagrams(String s, String p) {
List<Integer> list = new ArrayList<>();
Map<Character, Integer> map = new HashMap<>();
for (char c : p.toCharArray()) map.put(c, map.getOrDefault(c, 0)+1);
Map<Character, Integer> tmp = new HashMap<>();
for (int i = 0; i <= s.length() - p.length(); i++) {
for (int j = i; j < i + p.length(); j++) {
tmp.put(s.charAt(j), tmp.getOrDefault(s.charAt(j), 0)+1);
}
if (tmp.equals(map)) list.add(i);
tmp.clear();
}
return list;
}

  (2)Sliding Window

  2.代码:

  

Leetcode Tags(5)Hash Table的更多相关文章

  1. PHP内核探索之变量(3)- hash table

    在PHP中,除了zval, 另一个比较重要的数据结构非hash table莫属,例如我们最常见的数组,在底层便是hash table.除了数组,在线程安全(TSRM).GC.资源管理.Global变量 ...

  2. 交互设计算法基础(4) - Hash Table

    import java.util.Map; // Note the HashMap's "key" is a String and "value" is an ...

  3. Leetcode Tags(13)Bit Manipulation

    一.477.汉明距离总和 输入: , , 输出: 解释: 在二进制表示中,4表示为0100,14表示为1110,2表示为0010.(这样表示是为了体现后四位之间关系) HammingDistance( ...

  4. Leetcode Tags(13)Tree

    1.前序.中序.后序递归方式遍历二叉树 public void preOrderRecur(Node T) { if (T != null) { System.out.print(T.val + &q ...

  5. Leetcode Tags(8)Binary Search

    一.475. Heaters 输入: [1,2,3],[2] 输出: 1 解释: 仅在位置2上有一个供暖器.如果我们将加热半径设为1,那么所有房屋就都能得到供暖. 输入: [1,2,3,4],[1,4 ...

  6. Leetcode Tags(6)Math

    一.204. Count Primes Count the number of prime numbers less than a non-negative number, n. Input: 10 ...

  7. Leetcode Tags(3)String(TODO)

    一.Easy 696 Count Binary Substrings Input: "00110011" Output: 6 Explanation: There are 6 su ...

  8. Leetcode Tags(2)Array

    一.448. Find All Numbers Disappeared in an Array 给定一个范围在 1 ≤ a[i] ≤ n ( n = 数组大小 ) 的 整型数组,数组中的元素一些出现了 ...

  9. Leetcode Tags(1)Linked List

    1.知识点回顾 https://www.cnblogs.com/BigJunOba/p/9174206.html https://www.cnblogs.com/BigJunOba/p/9174217 ...

随机推荐

  1. Redis数据库安装与配置调试

    主要培养自我对Redis数据库安装能力, 并且进行个性化的数据库配置.掌握本实验的重点,即在于数据库的安装与启动参数的配置.同时,理解NOSQL数据库的体系结构. ①下载Redis安装包进行数据库平台 ...

  2. Spring 梳理-profile与条件化定义bean

    定义profile <beans> //root <beans profile="dev"> <bean id=.../> </beans ...

  3. OpenGl 实现鼠标分别移动多个物体 ----------移动一个物体另外一个物体不动--读取多个3d模型操作的前期踏脚石

    原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/11620088.html 前言: 因为接下来的项目需求是要读取多个3D模型,并且移动拼接,那么我 ...

  4. .Net Core 商城微服务项目系列(七):使用消息队列(RabbitMQ)实现服务异步通信

    RabbitMQ是什么,怎么使用我就不介绍了,大家可以到园子里搜一下教程.本篇的重点在于实现服务与服务之间的异步通信. 首先说一下为什么要使用消息队列来实现服务通信:1.提高接口并发能力.  2.保证 ...

  5. 死磕 java线程系列之创建线程的8种方式

    (手机横屏看源码更方便) 问题 (1)创建线程有哪几种方式? (2)它们分别有什么运用场景? 简介 创建线程,是多线程编程中最基本的操作,彤哥总结了一下,大概有8种创建线程的方式,你知道吗? 继承Th ...

  6. 基 B/S 平台的机房监控云平台-U位篇

    前言 机柜 U 位管理是一项突破性创新技术--继承了 RFID 标签(电子标签)的优点的同时,完全解决了 RFID 技术(非接触式的自动识别技术)在机房 U 位资产监控场应用景中的四大缺陷,采用工业互 ...

  7. java程序猿如何练习java版的易筋经?

    故事背景 电视剧<天龙八部>中,阿朱易容后进入少林寺偷走了<易筋经>,她一直想把这本书送给乔峰.耿直的乔峰觉得此书来历不正,不肯接受.几番波折,这本书最后落到聚贤庄庄主游坦之手 ...

  8. Oracle 存储过程判断语句正确写法和时间查询方法

    判断语句:if 条件 then   if  条件  then ************;   elsif  条件  then  ************;   elsif 条件  then ***** ...

  9. 30 分钟快速入门 Docker 教程

    原文地址:梁桂钊的博客 博客地址:http://blog.720ui.com 欢迎关注公众号:「服务端思维」.一群同频者,一起成长,一起精进,打破认知的局限性. 一.欢迎来到 Docker 世界 1. ...

  10. Java基础学习笔记(五) - 常用的API

    API介绍 概念:API 即应用编程程序接口.Java API是JDK中提供给我们使用的类说明文档,这些类将底层的代码实现封装.无需关心这些类是如何实现,只需要学习如何使用. 使用:通过API找到需要 ...