不用额外空间的整数交换以及时间复杂度为O(n)空间复杂度为O(1)的排序算法

本文探讨了一种无需额外空间的整数交换技巧以及一个时间复杂度为O(n)、空间复杂度为O(1)的排序算法——NiuabilitySort。该算法适用于数字范围受限的情况,通过基数组记录每个数字出现次数,然后更新排序数组。这种算法在面试中常被用作智力测试题目。
摘要由CSDN通过智能技术生成

一看题目这么长,聪明的你肯定已经猜到了这是个标题党。

据说这个某个公司的招聘题,某个追求时间和空间极限的bt程序员某个时间脑袋灵光一闪,搞出来这些个所谓的nb算法,然后再自豪地把它们呈给那些技术面试官,让他们用这些来测测我们这些普通程序员的脑袋是否灵光。然而,网络的发达或许让他们的这一想法完全落空,本来就是些高中生都能看懂的算法(似乎我没有夸张),加上网络一传播,地球人都知道了。所以到最后,也只能考考那些从未看过类似我这篇Blog的人:)。所以,我自己倒是更愿意把这个归为一道智力测试题。

国外已经有很多专家在质疑智力测试的准确性,在知识能够迅速获取的今天,很多智力题目只要你做过一次,第二次就不再是智力测试,而是记忆力测试了。所以很奇怪为什么现在面试官对智力测试有一种不可思议地喜欢,我们姑且称之为"智力测试喜好症候群"。

好了,言归正传,看过这篇Blog的ggmm以后面试碰上这种题目就不用经过大脑了,可以脱口而出,或者脱笔而出,或者脱X而出了(Coding,那是脱什么来着?)。

//不用temp的整数交换,一点点数学上的trick:)
void NotempSwap(int& a, int& b)
{
    a = a + b;
    b = a - b;
    a = a - b;
}

关于时间复杂度为O(n)以及空间复杂度为O(1)的整数排序算法,实际上是有前提的,面试官一般会这么问:

给定1000000个数,这些数都在0~65535之间,设计一个算法,将这

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值