以下是问题所在:
假设你有10万个整数,从1到1百万不等。请把整数分类。时间复杂度应为O(n)。
任何分享他或她的想法的人都会受到很好的赞赏。
发布于 2010-10-14 08:46:44
听起来像是简单的计数。
空间是恒定的。运行时为O(n)。
发布于 2010-10-14 08:46:44
暗示应该是,他们的范围从100万到100万。
请参阅针孔分类
发布于 2010-10-14 18:13:36
由于问题的大小是固定的,并且包含一个有限的实例集,所以任何排序算法都会在O(1)中终止。你应该让测试人员回到算法分析学校去。将这个问题推广到无限集合的一种可能方法是:您有一个大小为n的数组,其数字范围为0,10n。你能用O(n)分类吗?这对我来说很有意义。或者你可以用数组的大小和整数的范围来参数化这个问题,得到一些O(f(n,k))界。问题是当你在面试中遇到这样的问题时,你会怎么做?你是想猜面试官想听什么,还是说“让我重新表达你的问题”?还是你带着笑容朝出口走去?
https://stackoverflow.com/questions/3931464
复制相似问题