ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
12
返回列表 发新帖
楼主: jaxxcyh

[讨论] 0下沉问题,两种解法为何速度相差极大?

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-8-20 18:39 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
方法一找到下沉一次时,i循环+1还是在判断此0,往下最近的0非0已经被搬运前面了,意味着找一下非0更费循环,这样会把所有的0慢慢堆在中间知道堆到最后一个是0,循环量完全不是一个档次的
image.png

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-8-20 18:45 | 显示全部楼层
因为逆序扫描一下子将0换到了最后,而顺序是一个个的往下换,交换的次数多得多。

TA的精华主题

TA的得分主题

发表于 2024-8-20 18:51 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助

如果是这个结果,那以前的冒泡代码应该重写了。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-8-20 18:53 | 显示全部楼层
小凡、、、 发表于 2024-8-20 18:39
方法一找到下沉一次时,i循环+1还是在判断此0,往下最近的0非0已经被搬运前面了,意味着找一下非0更费循环 ...

这图好理解多了

TA的精华主题

TA的得分主题

发表于 2024-8-20 18:54 | 显示全部楼层

二个代码条件不同的,一个是cells(i,1)为条件,一个是cells(i,4)为条件。运行次数多少估计和这个条件有关。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-8-20 18:57 | 显示全部楼层
ykcbf1100 发表于 2024-8-20 18:51
如果是这个结果,那以前的冒泡代码应该重写了。

这个跟冒泡性质不同,冒泡里的双循环所有情况都得完整走一遍。这个只是把0挑出来,工作量自然少很多。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-8-20 19:01 | 显示全部楼层
ykcbf1100 发表于 2024-8-20 18:54
二个代码条件不同的,一个是cells(i,1)为条件,一个是cells(i,4)为条件。运行次数多少估计和这个条件有关 ...

跟这没关系。都是获取一个单元格数据,费时一样。难不成获取第十个单元格数据费时就得比第一个单元格的多?这不胡扯嘛。

TA的精华主题

TA的得分主题

发表于 2024-8-20 19:21 | 显示全部楼层
本帖最后由 shiruiqiang 于 2024-8-20 19:24 编辑
ykcbf1100 发表于 2024-8-20 18:51
如果是这个结果,那以前的冒泡代码应该重写了。

第一种叫冒泡排序,第二种应该叫选择排序(变异过的)

TA的精华主题

TA的得分主题

发表于 2024-8-20 19:36 | 显示全部楼层
shiruiqiang 发表于 2024-8-20 19:21
第一种叫冒泡排序,第二种应该叫选择排序(变异过的)

冒泡速度是有点慢的。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-18 14:23 , Processed in 0.033108 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表