56星座屋
当前位置: 首页 星座百科

python常见算法面试题(Python解答蚂蚁金服面试的算法题)

时间:2023-06-08 作者: 小编 阅读量: 1 栏目名: 星座百科

前几天看了一个视频,讲的是蚂蚁金服面试的一道算法题,题目是统计给定列表中的逆序数。在打开思路之前,先介绍一下什么是逆序数。对逆序数有了了解后,想必有一点python基础的朋友肯定就会想到最简单的一个思路,也是比较暴力的思路。虽然这三种思路都可以解决问题,不过速度却不一样。代码如写的有所不足,希望大家指出,在python学习的路上一起进步!

前几天看了一个视频,讲的是蚂蚁金服面试的一道算法题,题目是统计给定列表中的逆序数。

在打开思路之前,先介绍一下什么是逆序数。举个简单的例子,一个数组列表为:[5,3,1,1],其中逆序数有(5,3)、(5,1)、(5,1)、(3,1)、(3,1)总计5个。

对逆序数有了了解后,想必有一点python基础的朋友肯定就会想到最简单的一个思路,也是比较暴力的思路。

思路一:遍历统计法。

即用for循环取值,然后一个一个比较大小,设置一个变量,累加起来即可。代码如下,只有几行:

#Written by magiczsd# coding=UTF-8import timeli = [23,1,11,11,1,2,5,1,22]k = 0#设置一个变量kli_len = len(li)start = time.time()for i in li:#循环取列表里的数值和后面的数值比较大小k= 1for j in range(k,li_len):if i > li[j]:#如果为真,则变量加1num=1print(num)end = time.time()print(end-start)

思路一比较简单,大家也比较容易理解,但是既然这是蚂蚁金服面试的算法题,考官必定想看到能让眼睛一亮的思路,于是小编思考了下,想到了第二个思路。

思路二:最大值统计法。

即先用max函数查找出列表里最大的数值max_value,再用index函数查找最大值在列表里的第一个索引值max_index,接着再用count函数计算出列表里有几个最大值max_counts,最后用len函数计算列表里元素的个数len_num。

将max_index 1便得到这个最大值在列表中是第几个元素(注意:这里需要从1开始计算),用len统计的len_num-(max_index 1)便得到最大值右边的元素个数,最后再减去剩余的最大值个数即max_counts-1,这样便可以得到以这个最大值组成的逆序数个数。

然后用remove函数将这个最大值从列表里剔除,继续重复上面的步骤即可,代码如下:

#Written by magiczsd# coding=UTF-8import timeli = [23,1,11,11,1,2,5,1,22]num = 0def NiXuShu(li):len_num = len(li)#列表的元素个数max_value = max(li)#得到最大值max_index = li.index(max_value)#得到最大值在列表里的第一个位置的索引值max_counts = li.count(max_value)#统计列表里最大值的个数num = len_num - (max_index 1) - (max_counts-1)return num,max_value#返回以这个最大值组成的逆序数的个数和最大值start = time.time()while len(li) != 0:#循环处理,直到列表里最后一个最大值被剔除后,循环结束num= NiXuShu(li)[0]li.remove(NiXuShu(li)[1])#剔除第一个最大值print(num)end = time.time()print(end-start)

当时写完这段代码的时候,小编忽然灵光一闪,既然有最大值统计法,是否也可以有最小值统计法?于是很快最小值统计法的思路便有了。

思路三:最小值统计法。

先用min函数查找出列表里的最小值min_value,再用index查找出最小值在列表里的第一个索引值min_index,而这个min_index数值就是这个最小值与它左边的数值组成的逆序数的个数。

比如列表[3,2,1,4],最小值为1,与1组成的逆序数只有(3,1)、(2,1)数量是2,而其索引值也是2。

有了这样的思路,接下来的统计方法就和思路三的类似了,代码如下:

#Written by magiczsd# coding=UTF-8import timeli = [23,1,11,11,1,2,5,1,22]num = 0def NiXuShu(li):min_value = min(li)#得到列表里的最小值min_index = li.index(min_value)#最小值在列表的索引值num = min_index#索引值即为最小值与左边的数值组成的逆序数个数return num,min_valuestart = time.time()while len(li) != 0:#循环处理,直到列表里最后一个最小值被剔除后,循环结束num= NiXuShu(li)[0]li.remove(NiXuShu(li)[1])#剔除第一个最小值print(num)end = time.time()print(end-start)

上面的三种思路,第一种比较容易理解,第二种和第三种需要稍微思考下也是比较容易理解的。虽然这三种思路都可以解决问题,不过速度却不一样。在列表里的元素不多的时候,三种代码处理起来看不出差别,当元素达到上千上万甚至更多的时候,第一种处理起来会变得很慢,其次是第二种,速度最快的是第三种思路,有兴趣的朋友可以去测试一下。

代码如写的有所不足,希望大家指出,在python学习的路上一起进步!

代码已上传GitHub(https://github.com/magiczsd/office)

    推荐阅读
  • 形成酸雨的主要气体是什么(形成酸雨的主要气体)

    以下内容大家不妨参考一二希望能帮到您!形成酸雨的主要气体是什么酸雨是指PH小于5.6的雨雪或其他形式的降水,形成的主要气体有二氧化硫、三氧化硫、硫化氢、二氧化氮。酸雨主要是人为的向大气中排放大量酸性物质所造成的。酸雨又分硝酸型酸雨和硫酸型酸雨。

  • 木棉花的花语是什么(木棉花的意义)

    接下来我们就一起去了解一下吧!珍惜眼前的幸福,珍惜身边的人给他们快乐与幸福。它的花期通常在3月或者4月份,在这一段时间盛开,而传说中四月的第十一天,是木棉花盛开的日子,所以4月11被定为木棉花的日子。

  • 炒凉皮不碎技巧(炒凉皮不碎有什么技巧)

    以下内容大家不妨参考一二希望能帮到您!炒凉皮不碎技巧炒凉皮不碎技巧:就是在做凉皮时不能炒太久,变软会失去筋度。胡萝卜切丝,蒜薹切段,葱切花,猪肉切丝,大蒜拍扁。成品凉皮一张张卷起切粗条,抖散备用。生抽,白糖,盐,鸡精,醋,胡椒粉调成汁备用。热锅倒适量食用油烧热加入大蒜,肉丝翻炒至金黄,加入胡萝卜丝和蒜薹炒熟,凉皮翻炒均匀后随即淋入调好的汁儿翻炒均匀。

  • 近几年灭绝的鱼(瞭望在长江源寻鱼)

    长江被誉为我国淡水渔业的摇篮、鱼类基因的宝库。据青海省渔业部门统计,长江流域青海段分布有土著鱼类21种。因此,严格意义上长江源的关键鱼类指的是裂腹鱼中的小头裸裂尻鱼。2019年,李伟带领团队参加长江源科考时,将小头裸裂尻鱼列为长江源鱼类研究的代表对象。2019年4月,科考小组五个人,两台车,开始了沿河寻觅之旅。“全球平均气温上升已是科学界的共识,位于青藏高原的长江源是全球气候变化的敏感区。”科考发现,江源地区

  • 鹧鸪在什么时候季节鸣叫(鹧鸪的孵化期有多长)

    鹧鸪在什么时候季节鸣叫鹧鸪一般会在繁殖季节鸣叫,繁殖期为3-6月,3-4月间开始求偶交配。求偶期间鸣叫更为频繁,常在山岩、树桩、灌木或乔木枝上鸣叫,尤以黎明和黄昏时更甚,往往是一鸟先鸣叫,其他雄鸟一起跟随,此起彼伏。鹧鸪的孵化期在21天左右,雏鸟出壳后不久即可跟随亲鸟活动。鹧鸪的繁殖期为每年的3-6月,3-4月间开始求偶交配,每窝产卵3-6枚,多时可达8枚,卵为椭圆形或梨形,颜色为淡皮黄色至黄褐色。

  • 秋天的诗词(这些都是关于秋天的诗句)

    迢迢新秋夕,亭亭月将圆《戊申岁六月中遇火》,今天小编就来说说关于秋天的诗词?《戊申岁六月中遇火》自古逢秋悲寂寥,我言秋日胜春朝。《秋词》是处红衰翠减,苒苒物华休。惟有长江水,无语东流。宋·柳永《八声甘州》落时西风时候,人共青山都瘦。《昭君怨》雨色秋来寒,风严清江爽。《酬裴侍御对雨感时见赠》秋声万户竹,寒色五陵松。唐·李颀《望秦川》秋色无远近,出门尽寒山。宋·苏轼《九日次韵王巩》

  • 广州有几种车牌(广州车牌你有吗)

    在广州的普通上班族,有房贷还想拥有一辆车,已经不容易了。但有车想让个广州牌,那更是难上加难,再加之限行,参与摇号,竞价的人是越来越多,那中标的机会更是渺茫了!截止日期是8日24时止。9月拟配置的中小客车增量指标共16313个,是这样分配的:1.以摇号方式向单位和个人配置节能车增量指标7285个,其中,单位指标100个,个人指标7185个。

  • qq注销账号有哪几个步骤(QQ将开注销帐号功能)

    1999年2月10日,一个名为OICQ、只有几百K的软件正式上线。当时,腾讯方面表示,这是QQ团队对帐号注销功能的灰度测试。网友截图出于安全考虑,也有网友表示支持有人说,QQ不推出注销服务有自己的考虑,这是为了防止用户QQ密码被他人知道后恶意注销,给用户带来无法挽回的损失。腾讯2018年第三季度财报显示,QQ智能终端月活跃账户同比增长6.9%至6.979亿。

  • 高跟鞋不合脚怎么办(穿高跟鞋不合脚怎么办)

    4、合理利用袜子,如果不喜欢垫各种鞋垫的朋友,可以穿一双船袜,再穿高跟鞋,那样既不影响穿着效果,也不影响美观,也是比较简单和实用的方法。

  • 年四旺名字打分104分 年四旺事迹

    文章目录:一、年四旺相关名字打分113二、年四旺相关名字评分115三、年四旺相关名字推荐四、年四旺相关名字大全五、其他人还看了一、年四旺相关名字打分113年灯石志明年橘纪红兵武尊道后书法孔多塞年贷款孙敬媛年立秋里蓝业珍冯景华年见朱诗词林于思冯桂年粤日林格孟昭毅年家薛邑马布鱼鲁初雪苏沫沫卜庆中年上年掌柜秦源达刘登龙严学锋国韵酒年线高成江裘梦年维泗红沙日年周王克斌王翔千毛淑红龙威信李万和年神范小慧王大