Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
CSDN 技术社区
skill_tree_java
提交
49cf2bb1
S
skill_tree_java
项目概览
CSDN 技术社区
/
skill_tree_java
通知
43
Star
8
Fork
4
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
4
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
skill_tree_java
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
4
Issue
4
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
49cf2bb1
编写于
11月 16, 2021
作者:
M
Mars Liu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
group by
上级
0cb742f2
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
51 addition
and
24 deletion
+51
-24
data/3.Java高阶/5.分组/1.操作分组的元素/config.json
data/3.Java高阶/5.分组/1.操作分组的元素/config.json
+0
-8
data/3.Java高阶/5.分组/2.多级分组/config.json
data/3.Java高阶/5.分组/2.多级分组/config.json
+0
-8
data/3.Java高阶/5.分组/3.按子组收集数据/config.json
data/3.Java高阶/5.分组/3.按子组收集数据/config.json
+0
-8
data/3.Java高阶/5.分组/group_by.json
data/3.Java高阶/5.分组/group_by.json
+0
-0
data/3.Java高阶/5.分组/group_by.md
data/3.Java高阶/5.分组/group_by.md
+51
-0
未找到文件。
data/3.Java高阶/5.分组/1.操作分组的元素/config.json
已删除
100644 → 0
浏览文件 @
0cb742f2
{
"node_id"
:
"java-4cc01469b31d42ac80854c4024c1b15a"
,
"keywords"
:
[],
"children"
:
[],
"export"
:
[],
"title"
:
"操作分组的元素"
}
\ No newline at end of file
data/3.Java高阶/5.分组/2.多级分组/config.json
已删除
100644 → 0
浏览文件 @
0cb742f2
{
"node_id"
:
"java-873636226f0e44ad9269f2a13fe2adb9"
,
"keywords"
:
[],
"children"
:
[],
"export"
:
[],
"title"
:
"多级分组"
}
\ No newline at end of file
data/3.Java高阶/5.分组/3.按子组收集数据/config.json
已删除
100644 → 0
浏览文件 @
0cb742f2
{
"node_id"
:
"java-1223956aa7ae47a9a2e517dc23c3f371"
,
"keywords"
:
[],
"children"
:
[],
"export"
:
[],
"title"
:
"按子组收集数据"
}
\ No newline at end of file
data/3.Java高阶/5.分组/group_by.json
0 → 100644
浏览文件 @
49cf2bb1
data/3.Java高阶/5.分组/group_by.md
0 → 100644
浏览文件 @
49cf2bb1
# 分组
已知类型
```
java
public
class
Employee
{
int
id
;
String
name
;
String
department
;
}
```
将
`List<Employee> employee`
中的员工信息按部门分组,其中不正确的是:
## 答案
```
java
// List<Employee> employee = ...;
Map
<
String
,
Object
>
result
=
employee
.
stream
().
collect
(
toMap
(
Employee:
:
getDepartment
,
Function
.
identity
()));
```
## 选项
### 标准方法
```
java
// List<Employee> employee = ...;
Map
<
String
,
List
<
Employee
>>
result
=
employee
.
stream
().
collect
(
groupingBy
(
Employee:
:
getDepartment
));
```
### 朴素方法
```
java
// List<Employee> employee = ...;
Map
<
String
,
List
<
Employee
>>
result
=
new
HashMap
<>();
for
(
var
emp:
employee
){
var
list
=
result
.
getOrDefault
(
emp
.
department
,
new
ArrayList
<>());
list
.
add
(
emp
);
}
```
### 朴素方法
```
java
Map
<
String
,
List
<
Employee
>>
result
=
new
HashMap
<>();
for
(
int
index
=
0
;
index
<
employee
.
size
();
index
++){
var
emp
=
employee
.
get
(
index
);
var
list
=
result
.
getOrDefault
(
emp
.
department
,
new
ArrayList
<>());
list
.
add
(
emp
);
}
```
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录