- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 81
- 收听数
- 1
- 能力
- 120 分
- 体力
- 540758 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 167606
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5324
- 主题
- 5250
- 精华
- 18
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
. D& \0 V- d# X8 x2 a# @大数据必须掌握的三个基本算法
% H3 l! p4 \ @9 {一全排序' U0 h+ o [+ [% ? } r9 F
, \ V* v# r( o2 D
( e% F L5 l2 J" m6 R8 H( L
5 }5 ~" X- C" Y# P- {! Q K C& |( {( v& X/ n/ j( \
* o* v* z3 } S* Y
Hadoop自带的Partitioner的实现有两种,一种为HashPartitioner, 默认的分区方式,计算公式 hash(key)%reducernum,另一种为TotalOrderPartitioner, 为排序作业创建分区,分区中数据的范围需要通过分区文件来指定。& Q+ `. J0 b& W
m6 v" R: ]/ K3 m
% F7 p" R* ] c0 L7 x0 F 1 x. `3 p1 W: G
& Y6 n- M W8 n/ w. z$ [+ V) w; {; }; N
很多初学者,对大数据的概念都是模糊不清的,大数据是什么,能做什么,学的时候,该按照什么线路去学习,学完往哪方面发展,想深入了解,想学习的同学欢迎加入大数据学习qq群:199427210,有大量干货(零基础以及进阶的经典实战)分享给大家,并且有清华大学毕业的资深大数据讲师给大家免费授课,给大家分享目前国内最完整的大数据高端实战实用学习流程体系5 k) L' R: Q! ? H, a+ n7 ?
& i$ \- |* k; b' ]+ Y6 [2 g
; [( c, A+ b# J; L, K. O分区文件可以人为创建,如采用等距区间,如果数据分布不均匀导致作业完成时间受限于个别reduce任务完成时间的影响。
% m# K. q$ ]5 B1 o5 o' \$ s$ c6 g- E. Y) B/ Q0 z2 [
5 ]( J# }* p+ `6 y, W' b* l5 G也可以通过抽样器,先对数据进行抽样,根据数据分布生成分区文件,避免数据倾斜。
9 K4 U# c8 F! I7 o/ h- z6 y& w8 ^3 D. M7 K5 h! c7 K$ `* ~' G$ ~: t
& V( r! Q# M- w& Q/ U
注意,key可以是数字型,也可以是BinaryComparable(字符串),当是BinaryComparable时,则以key构造Trie Tree;否则以二分查找来确定key的所属区间。
' p' Z( C( E. q" F8 z J& L, U% s5 A5 {
5 f) x$ P6 }: u5 M1 Y5 J二单词共现矩阵算法 h$ x" u- [8 u' S
, Z! v% e2 B( G9 H# _# d' L. i
' R9 o0 V" o( N6 f4 O
9 z3 _# I" [6 b1 B0 i* K' j" p3 k7 Y7 K! M7 t- c7 A
2 q; C9 J0 g% Y, d& N
其目的是在海量语料库中发现在固定窗口内单词a和单词b共同出现的频率,从而构建单词共现矩阵,这样的矩阵可以是对称的,也可以是不对称的,这要看具体的应用。
/ _* ^7 ]8 `8 ?. B$ r3 T ~- ~" t; ^4 G. ? r9 f
( v: D, E2 j0 W) ~9 i
这种抽象化的任务的有效解决在实际生活中有着很多的应用。例如电子商家希望发现不同物品被同时购买的情况以便有效安排货物的摆放位置;同时对信息检索领域同义词词典的构建以及文本挖掘等都有着重要的实际应用价值。2 d* N: Y' _0 o( ^
8 N1 T6 m1 A( j# I8 J% g" W% w
" W8 m+ A. H/ G: Y& T1 a根据同现关系的不同,可能需要实现和定制不同的FileInputFormat和RecordReader,如同现关系为一个英文句子,则需要实现以一个英文句子为单位的FileInputFormat和RecordReader,如同现关系为一个段落,则需要实现以一个段落为单位的FileInputFormat和RecordReader
: n6 M0 v& p: l: z8 A& v2 W. H7 g& F. P5 o* C: b
$ z+ e$ u+ T+ Y" \. }4 a
( y I# @) n3 v7 Z9 p' ]" a N- c8 T! G4 e7 X$ F8 a4 x
三倒排索引
9 F' M# C6 A! j! A2 ?
7 F: S% D/ I$ c/ B* H* z" N# N7 s) O/ k+ m
; w! r8 d7 i2 P* G
~1 f$ i# Y8 { K1 ]6 N
: s5 h& @: q% M7 s6 B
1 m+ u( ?3 w+ P! `+ K U5 ?. ]" @5 A0 Y: x! n$ K! ~( M
9 \, H# K7 P5 l% y
3 e$ F0 J2 o+ o q' l! R* KInverted Index(倒排索引)是目前几乎所有支持全文检索的搜索引擎都要依赖的一个数据结构。基于索引结构,给出一个词(term),能取得含有这个term的文档列表(the list of documents),没什么可说的,必须掌握。+ `' l! G" b) C. a1 J4 ^/ d) [
————————————————, n/ j& w; ~) N' J/ O
版权声明:本文为CSDN博主「铁拳虎」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
& P! _1 m& d$ b, y: \2 b1 o原文链接:https://blog.csdn.net/juan189/article/details/84932486
1 C3 b! U9 O$ M, d& T- h7 }" ?: w! V; p+ v Y
8 [7 K! U% U( Y/ F* d |
zan
|