Coco学编程(二)--直接选择排序 (转)

Coco学编程(二)--直接选择排序 (转)[@more@]

Coco:这么长时间不来,我还真想大家,实在是某人太懒了,总也不来上课。

我:这个……还真是对不起啊。主要是因为最近找了份新工作,正在赶一个项目,比较忙一些。经常会有天黑才回来的事情,所以有很长一段时间没有出现。

Coco:据我所知~某人天黑才会回家,是因为在广州总迷路,每次坐在车上的时间还没有找路的时间长,而且,还因为一些很菜的程序问题被卡住了……

我:为什么总要揭我的短呀……-_-#

Coco:hoho,上课上课~

我:好吧,上次讲了直接插入排序,我们从改进它开始。这几天,你对这个算法有什么想法没有?

Coco:在书上读到,在容器中反复的插入和删除节点是一种很低效的做法,不但速度慢,还会造成内存的碎片化,是这样子的吧。

我:很正确,所以通常来说,我们应该想办法减少插入和删除的次数。这样可以有效避免内存的碎片化。

Coco:不过对于选择插入法来说,我们只移动出现逆序的节点了,还有什么办法能更进一步减少这插入和删除的操作吗?

我:有一个办法,就是不用del和Insert进行显示的删除和插入操作,充分利用容器现有的空间,以交换节点来移动它。

Coco:不太理解。

我:由些产生的最简单的方法,用简单的数学描述来讲,是这样子的,假设集合有{a1, a2, a3,…, an},我们先从整个区间中找出最小的一个元素am,如果它不等于a1,就把它和a1交换;然后查找[a2, a3,…, an]区间,在其中找出最小的元素,如果它不等于a2,就把它和a2交换;重复这一过程,就可以对整个数组排序了。

Coco:看起来很简单呀,我去试试,测试代码段就还用上次的喽~

#以下是Coco的代码:

#Direct choice sort. It is a sample method.

XML:namespace prefix = o ns = "urn:schemas-microsoft-com:Office:office" />

def DrtChcSort(theArray):

  #Move the begin of search area.

  for i in range(len(Array)):

  curMrk = i

  #Find the min node.

  for j in range(i, len(theArray)):

  if theArray[j] < theArray[curMrk]:

  curMrk = j

  #Move it to front.

  if not(curMrk == i):

  theArray[curMrk], theArray[i] = theArray[i], theArray[curMrk]

 

Array=[6,16,10,9,15,5,11,1,19,4,14,18,0,13,3,17,12,2,8,7]

print Array

DrtChcSort(Array)

print Array

Coco:这办法比上次那个简单多了嘛,为什么当初不教我这个?

我:要你写这些算法又不是真要你实用,主要是练习一下。要不然,对Python的数组排序最简单的办法应该是:Array.sort()

Coco:倒~好吧,算你说的有道理,不过这样直接交换链表中的元素:“theArray[curMrk], theArray[i] = theArray[i], theArray[curMrk]”真的可以保证内存不会碎片化,还能减少插入和删除吗?

我:老实说,我不知道,因为python对这个线性容器的操作被封装了起来,从我们这个使用层上,是看不到的。不过,我们至少避免了显示的增删操作。如果说这样编程是“可能会有坏结果”,那显示的增删操作则是“几乎一定会有坏结果”,如果在C语言这类直接操作内存的语言中,两者的效果就是很明确的了。

Coco:为什么说“几乎”?

我:因为python有它的内存管理机制,它可以进行垃圾回收,所以内存的碎片化和丢失,还是会受到控制,特别是jython,由于使用Java平台,基本上不存在内存方面的困扰。不过,过于依赖它也不是好主意,至少会给虚拟机带来不必要的负担。

Coco:听起来有道理的样子,我还有一个疑问,在这个排序中,我们把当前已排序间后面的那个元素直接与未排序区间中的最小元素交换了,这会不会造成后面的未排序区间越来越乱,给我们带来额外的麻烦呢?

我:这种交换的确有增加混乱――形像的说,就像热学中的“熵”――的可能,不过如果这个算法只考虑某一个链表,也就基本上没有什么用途了。而从统计角度讲,未排序区间的“熵”

不会因此而增加。

Coco:明白了,不过这个算法太简单了,再多讲点东西吧。

我:上次有个朋友问递归的含义,你知道吗?

Coco:递推多项式,一种表达式,每一项由前一项使用的公式来决定。

我:怎么看着这么眼熟啊,从哪里贴来的?

Coco:这么快就让你看出来了啊,《金山词霸》喽~

我:倒……真会偷懒,简单的说,递归的就是指一个方法中会使用它自身。

Coco:听起来怪怪的,给个程序让我们看看吧。

我:欧几里德算法,辗转相除求最大公因子,如何?你来写这个程序吧,也不是多难

Coco:真会偷懒~

def Gba(a, b):

  r = a%b

  if r == 0:

  return b

  else:

  return (b, r)

Coco:调用这个函数就可以得到a和b的最大公因子了。这种通过调用自身来进入下一步的函数就是一种递归函数吧。

我:是的,与之相对应的运算方法是迭代,也就是说通过某种方法重新记录当前状态,然后循环生成这一状态的算法,这样不用重复调用函数,在效率上比递归要好,不过可读性通常会差一些。比如以上这个Gba(a, b)的递归形式应该是这样子:

def Gba(a, b):

  r = a%b

  while r!=0:

  a, b = b, r

  r = a%b

  return b

Coco:好像明白点儿了。接下来呢?

我:上次去cn99新闻组上问你说的那个很菜的问题时,有位叫Chad.NETzer的朋友写了一个不错的回应,虽然我的问题很菜(Coco:这个笨蛋会不知道在python里怎么交换元素,也敢出来教别人,我真是遇人不淑呀~),但这位朋友写的回信比我的问题更有价值,如果明天有空,我把它译出来给大家分享一下。不过今天先这样吧,这两天感冒,不太舒服,明天还要上班。

Coco:感冒了不早说,别传染给我,闪~


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752019/viewspace-979861/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10752019/viewspace-979861/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: yolo-txtcoco-json工具是一种将YOLO格式的文本标注文件换为COCO格式的JSON标注文件的工具。YOLO(You Only Look Once)是一种目标检测算法,而COCO(Common Objects in Context)是一个常见的目标检测和图像分割数据集。有时候我们从YOLO标注工具中获得的标注结果是文本文件的形式,而在使用COCO数据集进行训练和评估时,我们需要将标注结果化为COCO格式的JSON文件。 这个工具可以实现这样的换过程,首先读取YOLO格式的文本文件并解析每个物体的位置、类别和边界框信息。然后根据这些信息结构化生成COCO JSON文件,其中包含了每个物体的类别、标签和位置信息。这样换之后,我们就可以直接使用COCO数据集上的目标检测算法进行训练或者评估。 使用yolo-txtcoco-json工具可以大大简化我们在YOLO和COCO之间进行标注格式换的过程,省去了手动编写换代码的复杂性和耗时。此外,将标注结果换为COCO格式也使得我们能够更加方便地使用COCO数据集的相关工具和算法进行目标检测任务的处理。 总之,yolo-txtcoco-json工具是一个方便实用的工具,可以帮助我们轻松地将YOLO格式的文本标注文件换为COCO格式的JSON标注文件,提高了目标检测任务的效率和准确性。 ### 回答2: yolo-txtcoco-json工具是一种用于将YOLO格式的标注文件换为COCO格式的工具。YOLO(You Only Look Once)是一种目标检测算法,其标注文件是以txt格式存储的,而COCO(Common Objects in Context)是一种通用的目标检测数据集格式,其标注文件以json格式存储。 使用yolo-txtcoco-json工具可以方便地将YOLO标注文件换为COCO格式,以便于在COCO格式下进行目标检测任务或者使用COCO预训练模型进行迁移习。 这个工具的主要功能是将YOLO标注文件中的目标边界框的位置信息、类别信息等提取出来,并按照COCO格式的要求,将这些信息整理为json格式的标注文件。 具体使用这个工具的步骤是:首先,将YOLO标注文件和对应的图片放置在同一个目录下;然后,运行工具提供的命令或脚本,指定输入目录和输出目录;最后,工具会自动遍历输入目录下的所有YOLO标注文件,将其换为相应的COCO格式,并输出到指定的输出目录中。 通过使用yolo-txtcoco-json工具,可以减少手动地从YOLO格式换为COCO格式的工作量,提高工作效率。同时,换后的COCO格式标注文件可以更方便地与其他基于COCO格式的目标检测算法或工具进行兼容和集成,便于进一步的数据处理和模型训练。 ### 回答3: yolo-txtcoco-json工具是一种用于将YOLO格式的标注文件换为COCO格式的标注文件的工具。YOLO格式的标注文件通常是一种纯文本文件,其中包含了每个目标物体的类别、位置和大小等信息。而COCO格式的标注文件是一种结构化的JSON文件,用于存储目标检测任务中的图像标注信息。 这个工具的主要功能是将YOLO格式的标注文件解析,并根据解析结果生成对应的COCO格式的标注文件。在换过程中,它会将YOLO的坐标信息进行换,以适应COCO标注的要求。同时,它还会将目标物体的类别信息换为COCO数据集中所使用的类别编码。换完成后,可以方便地使用生成的COCO格式的标注文件进行目标检测任务的训练和评估。 使用这个工具的好处是可以快速、准确地将YOLO格式的标注文件换为COCO格式的标注文件,从而方便地在COCO数据集上进行目标检测任务。这对于需要使用COCO格式数据集训练模型的研究人员和开发者来说非常有帮助。 总之,yolo-txtcoco-json工具是一种方便的工具,用于将YOLO格式的标注文件换为COCO格式的标注文件,使得目标检测任务的数据处理更加便捷高效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值