Redian新闻
>
我想说,我的A家电面,绝对是被烙印黑了,两个45分钟两个烙印
avatar
我想说,我的A家电面,绝对是被烙印黑了,两个45分钟两个烙印# JobHunting - 待字闺中
m*1
1
我前面发过一道题了,就是String 找repeat特征那道,要求算法复杂度为O(n),第二
题也是超级难。我都放上来。注意我的面试是SDE intern职位
第一题是一个口音极其重的烙印,几乎听不懂,还好是算法考试,要是纯聊天更完蛋。
题目如下:
1.有一种String,是把一个更短的String重复n次而构成的,那个更短的String长度至少为
2,输入一个String写代码返回T或者F
例子:
"abcabcabc" Ture 因为它把abc重复3次构成
"bcdbcdbcde" False 最后一个是bcde
"abcdabcd" True 因为它是abcd重复2次构成
"xyz" False 因为它不是某一个String重复
"aaaaaaaaaa" False 重复的短String长度应至少为2(这里不能看做aa重复5次)
要求算法复杂度为O(n)
public boolean isMultiple(String s){
}
这道题因为我开了一个单独贴了,就不在这里讨论了
第二个45分钟面试,是另外一个烙印,这个烙印的口音更重,更听不懂,但是他说话态
度nice一点,比前面一个感觉好一些。至少愿意重复问题。
2.有1 billion个Integer,要找出前100个最大的,并分析复杂度
这个题,我问了数据的大小范围,他说任何大小都有可能
我开始想用Radix排序,位移法
但是他好像觉得不合适。
他帮我算了一下,说1 B个整数正好是4G,然后让我继续想
我后来觉得是Heap sort,但是当时想不到
avatar
r*c
2
第二个不就是搞个size 100 heap么
avatar
d*e
3
尼玛的,这真的是在害人,真tmd老印!
intern居然还考这么难的!

少为

【在 m*********1 的大作中提到】
: 我前面发过一道题了,就是String 找repeat特征那道,要求算法复杂度为O(n),第二
: 题也是超级难。我都放上来。注意我的面试是SDE intern职位
: 第一题是一个口音极其重的烙印,几乎听不懂,还好是算法考试,要是纯聊天更完蛋。
: 题目如下:
: 1.有一种String,是把一个更短的String重复n次而构成的,那个更短的String长度至少为
: 2,输入一个String写代码返回T或者F
: 例子:
: "abcabcabc" Ture 因为它把abc重复3次构成
: "bcdbcdbcde" False 最后一个是bcde
: "abcdabcd" True 因为它是abcd重复2次构成

avatar
h*6
4
我觉得作为intern的面试挺难的了这些题 除非之前看到过
avatar
m*l
5
第一题要求线性是很BT
第二题很难吗?
我觉着就是maintain一个size 100 的minHeap啊
复杂度nlogK
还是有什么需要注意的?
avatar
c*0
6
第二题应该用双层桶。我觉得他家全职也没这么难…

少为

【在 m*********1 的大作中提到】
: 我前面发过一道题了,就是String 找repeat特征那道,要求算法复杂度为O(n),第二
: 题也是超级难。我都放上来。注意我的面试是SDE intern职位
: 第一题是一个口音极其重的烙印,几乎听不懂,还好是算法考试,要是纯聊天更完蛋。
: 题目如下:
: 1.有一种String,是把一个更短的String重复n次而构成的,那个更短的String长度至少为
: 2,输入一个String写代码返回T或者F
: 例子:
: "abcabcabc" Ture 因为它把abc重复3次构成
: "bcdbcdbcde" False 最后一个是bcde
: "abcdabcd" True 因为它是abcd重复2次构成

avatar
m*l
7
能不能解释下 minHeap为什么不行?

【在 c******0 的大作中提到】
: 第二题应该用双层桶。我觉得他家全职也没这么难…
:
: 少为

avatar
w*i
8
minheap达不到线性时间,注意这里是整数,范围有限。其实还有种不断调用类似于快
排中partition的方法,可以线性时间求解,搜下top k就知道了。

【在 m********l 的大作中提到】
: 能不能解释下 minHeap为什么不行?
avatar
j*d
9
第二题 用radix sort为什么不行, 是因为空间开销太大吗?
avatar
h*k
10
1B的整数正好是4G是什么意思?

少为

【在 m*********1 的大作中提到】
: 我前面发过一道题了,就是String 找repeat特征那道,要求算法复杂度为O(n),第二
: 题也是超级难。我都放上来。注意我的面试是SDE intern职位
: 第一题是一个口音极其重的烙印,几乎听不懂,还好是算法考试,要是纯聊天更完蛋。
: 题目如下:
: 1.有一种String,是把一个更短的String重复n次而构成的,那个更短的String长度至少为
: 2,输入一个String写代码返回T或者F
: 例子:
: "abcabcabc" Ture 因为它把abc重复3次构成
: "bcdbcdbcde" False 最后一个是bcde
: "abcdabcd" True 因为它是abcd重复2次构成

avatar
m*l
11
1B的整数就是有1 billion个int
1 int = 4 bytes
1 billion int = 4 billion bytes ~ 4GB
就是大概需要4GB的内存来存储1 billion个int

【在 h**k 的大作中提到】
: 1B的整数正好是4G是什么意思?
:
: 少为

avatar
m*l
12
topK的minheap算法不就是线性时间吗? 复杂度nlogK 这道题说了K=100远小于n,所以
就是线性的啊,而且就算K很大,logK也大不到哪里去。所以我觉得TopK的这个算法最
好用了。
另外我们不用计数排序的话,就跟范围没关系了吧,每次和minHeap的top比较就行了
快速选择那种解法比较复杂,要用到median of medians什么的才能保证worst case 是
O(n), 但是这个要写代码难度很大(对我来说)。我不懂这个方法比minheap相比好在
哪里,节省空间?

【在 w*******i 的大作中提到】
: minheap达不到线性时间,注意这里是整数,范围有限。其实还有种不断调用类似于快
: 排中partition的方法,可以线性时间求解,搜下top k就知道了。

avatar
w*s
13
第二题第一反应就是heap sort

少为

【在 m*********1 的大作中提到】
: 我前面发过一道题了,就是String 找repeat特征那道,要求算法复杂度为O(n),第二
: 题也是超级难。我都放上来。注意我的面试是SDE intern职位
: 第一题是一个口音极其重的烙印,几乎听不懂,还好是算法考试,要是纯聊天更完蛋。
: 题目如下:
: 1.有一种String,是把一个更短的String重复n次而构成的,那个更短的String长度至少为
: 2,输入一个String写代码返回T或者F
: 例子:
: "abcabcabc" Ture 因为它把abc重复3次构成
: "bcdbcdbcde" False 最后一个是bcde
: "abcdabcd" True 因为它是abcd重复2次构成

avatar
g*4
14
第2题是glassdoor上他们家的原题啊,intern类别
算是比较经典了,微软也考过

少为

【在 m*********1 的大作中提到】
: 我前面发过一道题了,就是String 找repeat特征那道,要求算法复杂度为O(n),第二
: 题也是超级难。我都放上来。注意我的面试是SDE intern职位
: 第一题是一个口音极其重的烙印,几乎听不懂,还好是算法考试,要是纯聊天更完蛋。
: 题目如下:
: 1.有一种String,是把一个更短的String重复n次而构成的,那个更短的String长度至少为
: 2,输入一个String写代码返回T或者F
: 例子:
: "abcabcabc" Ture 因为它把abc重复3次构成
: "bcdbcdbcde" False 最后一个是bcde
: "abcdabcd" True 因为它是abcd重复2次构成

avatar
T*U
15
第二题不难吧,不是o(n)吗

少为

【在 m*********1 的大作中提到】
: 我前面发过一道题了,就是String 找repeat特征那道,要求算法复杂度为O(n),第二
: 题也是超级难。我都放上来。注意我的面试是SDE intern职位
: 第一题是一个口音极其重的烙印,几乎听不懂,还好是算法考试,要是纯聊天更完蛋。
: 题目如下:
: 1.有一种String,是把一个更短的String重复n次而构成的,那个更短的String长度至少为
: 2,输入一个String写代码返回T或者F
: 例子:
: "abcabcabc" Ture 因为它把abc重复3次构成
: "bcdbcdbcde" False 最后一个是bcde
: "abcdabcd" True 因为它是abcd重复2次构成

avatar
s*u
16
什么是HEAP SORT?
就是选个百人队排序,然后把剩下的每个数字跟百人里面
最小的比较一下,优胜劣汰?
avatar
F*9
17
第二题也算是提示你用bitmap了吧:
说1 B个整数正好是4G,
avatar
l*b
18
build heap + pull k times = n + k log n 可能比 n log k 强点

【在 s****u 的大作中提到】
: 什么是HEAP SORT?
: 就是选个百人队排序,然后把剩下的每个数字跟百人里面
: 最小的比较一下,优胜劣汰?

avatar
P*o
19
面试问难题无非是冠冕堂皇的不要你,你被烙印玩了。

少为

【在 m*********1 的大作中提到】
: 我前面发过一道题了,就是String 找repeat特征那道,要求算法复杂度为O(n),第二
: 题也是超级难。我都放上来。注意我的面试是SDE intern职位
: 第一题是一个口音极其重的烙印,几乎听不懂,还好是算法考试,要是纯聊天更完蛋。
: 题目如下:
: 1.有一种String,是把一个更短的String重复n次而构成的,那个更短的String长度至少为
: 2,输入一个String写代码返回T或者F
: 例子:
: "abcabcabc" Ture 因为它把abc重复3次构成
: "bcdbcdbcde" False 最后一个是bcde
: "abcdabcd" True 因为它是abcd重复2次构成

avatar
j*p
20
这是做样子给HR看的,黑的就是你,
谁让你不是印度人?
老印把事情做绝了,会有报应的.
avatar
c*y
21
我怎么也感觉第二题就是用bitmap呢?O(n)
avatar
H*a
22
lz说他问了这些数大小没有范围的,这样的话,bitmap是不能使用的吧。因为你不知道
需要多少个bit来表达数字。大家觉得呢?

【在 F********9 的大作中提到】
: 第二题也算是提示你用bitmap了吧:
: 说1 B个整数正好是4G,

avatar
s*z
23
我觉得还好,不能算是故意刁难.
有一点是面试里面听不懂一定要求他说清楚, 没有说清楚是他的责任, 但是听不清楚就
做题是你的责任了, 就是平时间deliver东西一个道理, 你不做都比assign给你以后不
完成要强的.
第二个应该heapsort和bitmap都是比较好的法子了.
avatar
p*y
24
第二题的题型,十多年前就开始在面试界流行了。
avatar
e*n
25
对正经学过算法的人不算难,但要拿来为难外行,只能显出烙印的狭隘。拿个教材里的
数学题来问这种烙印就足够把他们折腾死了。
相关阅读
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。