python统计程序运行次数_使用Python快排统计次数的问题

问 题

1,刚刚被问懵了。我都害怕。请问如下代码中的count是不是记录了全部的次数。使用了一个全局变量count来记录比较的次数。争论的重点在于两个if是否要算入计数中。我认为这个属于开始执行和结束执行的条件。请教以下。

# -*- coding:utf-8 -*-

import logging, copy

"""

快速排序

"""

def quicksort(mylist, first, last):

if first < last:

piovt = partition(mylist, first, last)

quicksort(mylist, first, piovt-1)

quicksort(mylist, piovt+1, last)

return mylist,

def partition(mylist, first, last):

global count

pivotValue = mylist[first]

left = first + 1

right = last

done = False

while not done:

count = count+1

while left <= right and mylist[left] <= pivotValue:

count = count + 1

left = left + 1

while mylist[right] >= pivotValue and right >= left:

count = count+1

right = right - 1

if right < left:

done = True

else:

temp = mylist[left]

mylist[left] = mylist[right]

mylist[right] = temp

temp = mylist[first]

mylist[first] = mylist[right]

mylist[right] = temp

return right

if __name__ == '__main__':

count = 0

logging.basicConfig(

level=logging.DEBUG, format='%(asctime)s-%(levelname)s => %(message)s')

myListinit=[7,2,5,1,29,6,4,19,11]

mylist = copy.deepcopy(myListinit)

isIn = quicksort(mylist, 0, len(mylist)-1)

if isIn :

logging.debug(

'\nbefore:%s\nafter:%s\n%d' %(myListinit, isIn, count))

解决方案

你的代码是对的, if first < last: 不用加 这算是执行前的条件, if right < left:你上面已经加过一次 不管它进没进if

wx.jpg

扫一扫关注IT屋

微信公众号搜索 “ IT屋 ” ,选择关注与百万开发者在一起

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值